Source

main-silver / java.source / apichanges.xml

Full commit
  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
 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
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
<?xml version="1.0" encoding="UTF-8"?>
<!-- Search for CHANGEME in this document when copying and using it: -->
<!--
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.

Copyright 1997-2010 Oracle and/or its affiliates. All rights reserved.

Oracle and Java are registered trademarks of Oracle and/or its affiliates.
Other names may be trademarks of their respective owners.


The contents of this file are subject to the terms of either the GNU
General Public License Version 2 only ("GPL") or the Common
Development and Distribution License("CDDL") (collectively, the
"License"). You may not use this file except in compliance with the
License. You can obtain a copy of the License at
http://www.netbeans.org/cddl-gplv2.html
or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
specific language governing permissions and limitations under the
License.  When distributing the software, include this License Header
Notice in each file and include the License file at
nbbuild/licenses/CDDL-GPL-2-CP.  Oracle designates this
particular file as subject to the "Classpath" exception as provided
by Oracle in the GPL Version 2 section of the License file that
accompanied this code. If applicable, add the following below the
License Header, with the fields enclosed by brackets [] replaced by
your own identifying information:
"Portions Copyrighted [year] [name of copyright owner]"

Contributor(s):

The Original Software is NetBeans. The Initial Developer of the Original
Software is Sun Microsystems, Inc. Portions Copyright 1997-2010 Sun
Microsystems, Inc. All Rights Reserved.

If you wish your version of this file to be governed by only the CDDL
or only the GPL Version 2, indicate your decision by adding
"[Contributor] elects to include this software in this distribution
under the [CDDL or GPL Version 2] license." If you do not indicate a
single choice of license, a recipient has the option to distribute
your version of this file under either the CDDL, the GPL Version 2 or
to extend the choice of license to its licensees as provided above.
However, if you add GPL Version 2 code and therefore, elected the GPL
Version 2 license, then the option applies only if the new code is
made subject to such option by the copyright holder.
-->
<?xml-stylesheet type="text/xml" href="../nbbuild/javadoctools/apichanges.xsl"?>
<!DOCTYPE apichanges PUBLIC "-//NetBeans//DTD API changes list 1.0//EN" "../nbbuild/javadoctools/apichanges.dtd">

<!--

INFO FOR PEOPLE ADDING CHANGES:

Check the DTD (apichanges.dtd) for details on the syntax. You do not
need to regenerate the HTML, as this is part of Javadoc generation; just
change the XML. Rough syntax of a change (several parts optional):

<change>
    <api name="compiler"/>
    <summary>Some brief description here, can use <b>XHTML</b></summary>
    <version major="1" minor="99"/>
    <date day="13" month="6" year="2001"/>
    <author login="jrhacker"/>
    <compatibility addition="yes"/>
    <description>
        The main description of the change here.
        Again can use full <b>XHTML</b> as needed.
    </description>
    <class package="org.openide.compiler" name="DoWhatIWantCompiler"/>
    <issue number="14309"/>
</change>

Also permitted elements: <package>, <branch>. <version> is API spec
version, recommended for all new changes. <compatibility> should say
if things were added/modified/deprecated/etc. and give all information
related to upgrading old code. List affected top-level classes and
link to issue numbers if applicable. See the DTD for more details.

Changes need not be in any particular order, they are sorted in various
ways by the stylesheet anyway.

Dates are assumed to mean "on the trunk". If you *also* make the same
change on a stabilization branch, use the <branch> tag to indicate this
and explain why the change was made on a branch in the <description>.

Please only change this file on the trunk! Rather: you can change it
on branches if you want, but these changes will be ignored; only the
trunk version of this file is important.

Deprecations do not count as incompatible, assuming that code using the
deprecated calls continues to see their documented behavior. But do
specify deprecation="yes" in <compatibility>.

This file is not a replacement for Javadoc: it is intended to list changes,
not describe the complete current behavior, for which ordinary documentation
is the proper place.

-->

<apichanges>

    <!-- First, a list of API names you may use: -->
    <apidefs>
        <apidef name="general">Java Source API</apidef>
        <!-- etc. -->
    </apidefs>

    <!-- ACTUAL CHANGES BEGIN HERE: -->

    <changes>
        <change id="run-modification-task-sourceless">
             <api name="general"/>
             <summary>JavaSource.runModificationTask can run on source-less JavaSources</summary>
             <version major="0" minor="74"/>
             <date day="21" month="1" year="2011"/>
             <author login="jlahoda"/>
             <compatibility addition="no" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 <code>JavaSource.runModificationTask</code> method works on source-less <code>JavaSource</code>s.
             </description>
             <class package="org.netbeans.api.java.source" name="JavaSource"/>
             <issue number="119887"/>
        </change>
        <change id="index-based-is-main">
             <api name="general"/>
             <summary>Added a method for checking the existence of the main method using index only</summary>
             <version major="0" minor="71"/>
             <date day="10" month="12" year="2010"/>
             <author login="tzezula"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added a new version of the <code>isMain</code> method into <code>org.netbeans.api.java.source.SourceUtils</code> which allows
                 check based only on index information.
             </description>
             <class package="org.netbeans.api.java.source" name="SourceUtils"/>
             <issue number="191648"/>
        </change>
        <change id="jdk7-update-2">
             <api name="general"/>
             <summary>DisjointTypeTree renamed to DisjunctiveTypeTree, AnnotationTypeTree has been removed</summary>
             <version major="0" minor="70"/>
             <date day="12" month="11" year="2010"/>
             <author login="jlahoda"/>
             <compatibility binary="incompatible" deletion="no" deprecation="no" modification="yes" semantic="compatible" source="incompatible"/>
             <description>
                 <code>com.sun.source.tree.DisjointTypeTree</code> renamed to <code>com.sun.source.tree.DisjunctiveTypeTree</code> from javac,
                 so adjusting <code>TreeMaker</code> to it. <code>com.sun.source.tree.AnnotationTypeTree</code> has been removed from javac and
                 is no longer available.
             </description>
             <class package="org.netbeans.api.java.source" name="TreeMaker"/>
        </change>
        <change id="jdk7-update">
             <api name="general"/>
             <summary>Added several methods to support new API for modeling JDK7 features.</summary>
             <version major="0" minor="67"/>
             <date day="12" month="10" year="2010"/>
             <author login="jlahoda"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added <code>CodeStyle.alignMultilineTryResources</code>, <code>CodeStyle.spaceBeforeTryParen</code>,
                 <code>CodeStyle.spaceWithinTryParens</code>, <code>CodeStyle.wrapTryResources</code>
                 <code>TreeMaker.DisjointType</code>, <code>CodeStyle.Try</code> and <code>TreeUtilities.CLASS_TREE_KINDS</code>
                 to support new language features in JDK7.
             </description>
             <issue number="190767"/>
        </change>
        <change id="TreeMaker.PackageAnnotations">
             <api name="general"/>
             <summary>Added TreeMaker.CompilationUnit(List&lt;AnnotationTree&gt;, ...), TreeMaker.addPackageAnnotation, TreeMaker.insertPackageAnnotation, TreeMaker.removePackageAnnotation methods.</summary>
             <version major="0" minor="66"/>
             <date day="27" month="9" year="2010"/>
             <author login="jlahoda"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added <code>TreeMaker.CompilationUnit(List&lt;AnnotationTree&gt;, ...)</code>,
                 <code>TreeMaker.addPackageAnnotation</code>, <code>TreeMaker.insertPackageAnnotation</code>,
                 <code>TreeMaker.removePackageAnnotation</code> to allow modification of the list of package annotations.
             </description>
             <class package="org.netbeans.api.java.source" name="TreeMaker"/>
             <issue number="157760"/>
        </change>
        <change id="TreeMaker.QualIdent_String">
             <api name="general"/>
             <summary>Added TreeMaker.QualIdent(String) and TreeMaker.Type(String) method.</summary>
             <version major="0" minor="65"/>
             <date day="16" month="9" year="2010"/>
             <author login="jlahoda"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added <code>TreeMaker.QualIdent(String)</code> and <code>TreeMaker.Type(String)</code> method, which allow
                 to construct QualIdents and Types from String specification.
             </description>
             <class package="org.netbeans.api.java.source" name="TreeMaker"/>
             <issue number="190123"/>
        </change>
        <change id="TreeUtilities.translate">
             <api name="general"/>
             <summary>Added TreeUtilities.translate method.</summary>
             <version major="0" minor="64"/>
             <date day="8" month="9" year="2010"/>
             <author login="jlahoda"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added <code>TreeUtilities.translate</code> method, which allows
                 to construct new tree based on a given set of changes.
             </description>
             <class package="org.netbeans.api.java.source" name="TreeUtilities"/>
             <issue number="190019"/>
        </change>
        <change id="TypeUtilities.getTypeName">
             <api name="general"/>
             <summary>Added TypeUtilities.getTypeName method.</summary>
             <version major="0" minor="62"/>
             <date day="13" month="7" year="2010"/>
             <author login="jlahoda"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added <code>TypeUtilities.getTypeName</code> method, which
                 allows to print type to string.
             </description>
             <class package="org.netbeans.api.java.source" name="TypeUtilities"/>
             <issue number="104194"/>
        </change>
        <change id="SourceUtils.getAttributeValueCompletions">
             <api name="general"/>
             <summary>Added SourceUtils.getAttributeValueCompletions method.</summary>
             <version major="0" minor="57"/>
             <date day="2" month="3" year="2010"/>
             <author login="dbalek"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added <code>SourceUtils.getAttributeValueCompletions</code> method, which
                 returns a list of completions for an annotation attribute value suggested by
                 annotation processors.
             </description>
             <class package="org.netbeans.api.java.source" name="SourceUtils"/>
             <issue number="111292"/>
        </change>
        <change id="TreeUtilities.exotic">
             <api name="general"/>
             <summary>Added support for encoding/decoding exotic identifiers to TreeUtilities.</summary>
             <version major="0" minor="56"/>
             <date day="24" month="2" year="2010"/>
             <author login="jlahoda"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                Added support for encoding/decoding exotic identifiers to <code>TreeUtilities</code>.
             </description>
             <class package="org.netbeans.api.java.source" name="TreeUtilities"/>
             <issue number="180842"/>
        </change>
        <change id="GeneratorUtilities.copyComments">
             <api name="general"/>
             <summary>Added GeneratorUtilities.copyComments method.</summary>
             <version major="0" minor="51"/>
             <date day="27" month="10" year="2009"/>
             <author login="jlahoda"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added <code>GeneratorUtilities.copyComments</code> method, which
                 copies comments from one tree to another tree.
             </description>
             <class package="org.netbeans.api.java.source" name="GeneratorUtilities"/>
             <issue number="175020"/>
        </change>
        <change id="TreeUtilities.isEnumConstant">
             <api name="general"/>
             <summary>Added TreeUtilities.isEnumConstant() method.</summary>
             <version major="0" minor="48"/>
             <date day="14" month="8" year="2009"/>
             <author login="msauer"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added <code>TreeUtilities.isEnumConstant()</code> method, which
                 determines whether tree represents an enum constant.
             </description>
             <class package="org.netbeans.api.java.source" name="TreeUtilities"/>
             <issue number="170373"/>
        </change>
        <change id="CompilationInfo.getSourceVersion">
             <api name="general"/>
             <summary>Added CompilationInfo.getSourceVersion() method.</summary>
             <version major="0" minor="47"/>
             <date day="12" month="8" year="2009"/>
             <author login="dbalek"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added <code>CompilationInfo.getSourceVersion()</code> to return the SourceVersion used by the javac compiler.
             </description>
             <class package="org.netbeans.api.java.source" name="CompilationInfo"/>
             <issue number="169970"/>
        </change>
        <change id="JavaSource.patchedPublic">
             <api name="general"/>
             <summary>Removing the binary compatibility methods (using bytecode patching) from JavaSource</summary>
             <version major="0" minor="46"/>
             <date day="6" month="8" year="2009"/>
             <author login="tzezula"/>
             <compatibility binary="incompatible" deletion="yes" source="compatible"/>
             <description>
                 The JavaSource class contains methods introduced to keep binary compatibility among milestones of NB 6.0.
                 These methods are not needed anymore and will be removed.
             </description>
             <class package="org.netbeans.api.java.source" name="JavaSource"/>
             <issue number="169974"/>
        </change>
        <change id="TreeMaker.Method">
             <api name="general"/>
             <summary>Added new Method allowing creating varargs methods.</summary>
             <version major="0" minor="44"/>
             <date day="7" month="5" year="2009"/>
             <author login="moonko"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Adding <code>TreeMake.Method(..., boolean isVarArg)</code> to allow creation of methods with variable lenght of arguments.
             </description>
            <class package="org.netbeans.api.java.source" name="TreeMaker"/>
        </change>
        <change id="Comment.create">
             <api name="general"/>
             <summary>Changed Comment API</summary>
             <version major="0" minor="43"/>
             <date day="31" month="3" year="2009"/>
             <author login="moonko"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Adding <code>Comment.create(Comment.Style, String)</code> to create new comment of any style from string.
             </description>
             <class package="org.netbeans.api.java.source" name="Comment"/>
        </change>
        <change id="parsing.api">
             <api name="general"/>
             <summary>Migrated to the parsing.api</summary>
             <version major="0" minor="42"/>
             <date day="24" month="11" year="2008"/>
             <author login="tzezula"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="yes" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 The java source module migrated to use the common parsing api.
             </description>
             <class package="org.netbeans.api.java.source" name="JavaParserResultTask"/>
             <class package="org.netbeans.api.java.source" name="ClasspathInfo"/>
             <class package="org.netbeans.api.java.source" name="CompilationInfo"/>
             <class package="org.netbeans.api.java.source" name="CompilationController"/>
             <class package="org.netbeans.api.java.source" name="ModificationResult"/>
             <class package="org.netbeans.api.java.source" name="WorkingCopy"/>
        </change>
        <change id="CodeStyle.getDefault">
             <api name="general"/>
             <summary>Better ways of getting CodeStyle instance</summary>
             <version major="0" minor="39"/>
             <date day="13" month="8" year="2008"/>
             <author login="vstejskal"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="yes" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added <code>CodeStyle.getDefault(FileObject)</code>, <code>CodeStyle.getDefault(Document)</code>.
                 Deprecated <code>CodeStyle.getDefault(Project)</code>.
             </description>
             <class package="org.netbeans.api.java.source" name="CodeStyle" />
        </change>
        <change id="BuildArtifactMapper">
             <api name="general"/>
             <summary>Added BuildArtifactMapper</summary>
             <version major="0" minor="38"/>
             <date day="7" month="7" year="2008"/>
             <author login="jlahoda"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added BuildArtifactMapper.
             </description>
             <class package="org.netbeans.api.java.source" name="BuildArtifactMapper" />
        </change>
        <change id="TaggingSupport">
             <api name="general"/>
             <summary>Added ModificationResult.getSpan and WorkingCopy.tag</summary>
             <version major="0" minor="37"/>
             <date day="25" month="6" year="2008"/>
             <author login="msauer"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added Methods allowing tagging of trees and getting their span inside modified document.
             </description>
        </change>
        <change id="TypeUtilities.substitute">
             <api name="general"/>
             <summary>Added TypeUtilities.substitute</summary>
             <version major="0" minor="36"/>
             <date day="6" month="5" year="2008"/>
             <author login="jlahoda"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added TypeUtilities.substitute.
             </description>
             <class package="org.netbeans.api.java.source" name="TypeUtilities" />
        </change>
        <change id="GeneratorUtilities.createMethod">
             <api name="general"/>
             <summary>Added GeneratorUtilities.createMethod</summary>
             <version major="0" minor="34"/>
             <date day="25" month="3" year="2008"/>
             <author login="jlahoda"/>
             <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
             <description>
                 Added method to create a new method tree for given method element.
             </description>
            <issue number="130240"/>
        </change>
        <change id="CommitToGuards">
            <api name="general"/>
            <summary>Added ModificationResult.Difference.setCommitToGuards(boolean) and isCommitToGuards() methods permitting to write modifications even to guarded sections</summary>
            <version major="0" minor="33"/>
            <date day="15" month="3" year="2008"/>
            <author login="jpokorsky"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                Added methods to allow ModificationResult to write changes into guarded sections of a document in case the API client
                is aware of what he does.
            </description>
        </change>
        <change id="PartialReparseAPI">
            <api name="general"/>
            <summary>Added CompilationInfo.getChangedTree method returning the reparsed subtree</summary>
            <version major="0" minor="31"/>
            <date day="25" month="1" year="2008"/>
            <author login="tzezula"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                Added method to return the reparsed subtree of the CompilationUnit tree, the result of this method should be used as a hint
                for the registered tasks to update model only for the changed subtree rather than for the whole CompilationUnit tree.
            </description>
        </change>
        <change id="CancellableScannerAtomicBoolean">
            <api name="general"/>
            <summary>Added CancellableTreePathScanner(AtomicBoolean) and CancellableTreeScanner(AtomicBoolean)</summary>
            <version major="0" minor="30"/>
            <date day="21" month="12" year="2007"/>
            <author login="jlahoda"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                Added constructors taking AtomicBoolean to the CancellableTreePathScanner and CancellableTreeScanner.
            </description>
            <issue number="123762"/>
        </change>
        <change id="ElementHandle-from">
            <api name="general"/>
            <summary>Added a method to obtain ElementHandles from TypeMirrorHandles representing DeclaredTypes</summary>
            <version major="0" minor="29"/>
            <date day="14" month="12" year="2007"/>
            <author login="dbalek"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                Added a method to obtain ElementHandles from TypeMirrorHandles representing DeclaredTypes.
            </description>
            <issue number="123971"/>
        </change>
        <change id="CAMEL_CASE_INSENSITIVE">
            <api name="general"/>
            <summary>Added ClassIndex.NameKind.CAMEL_CASE_INSENSITIVE</summary>
            <version major="0" minor="28"/>
            <date day="26" month="11" year="2007"/>
            <author login="tzezula"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                Added ClassIndex.NameKind.CAMEL_CASE_INSENSITIVE used by code completion for getting camel case names.
            </description>
            <issue number="122864"/>
        </change>
        <change id="jsp-dialogs">
            <api name="general"/>
            <summary>Support for JSPs and dialogs</summary>
            <version major="0" minor="21"/>
            <date day="15" month="6" year="2007"/>
            <author login="jlahoda"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                Adding ability to use Java infrastructure for non-Java file (eg. JSP files) and inside dialogs.
            </description>
            <issue number="106629"/>
        </change>
        <change id="GeneratorUtilities">
            <api name="general"/>
            <summary>Adding GeneratorUtilities</summary>
            <version major="0" minor="20"/>
            <date day="15" month="6" year="2007"/>
            <author login="jlahoda"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                A utility class, org.netbeans.api.java.source.GeneratorUtilities has been added.
            </description>
            <issue number="106678" />
        </change>
        <change id="JavaSource-Cleanup1">
            <api name="general"/>
            <summary>Removal of obsolete, duplicated and deprecated methods from java/source</summary>
            <version major="0" minor="19"/>
            <date day="15" month="6" year="2007"/>
            <author login="jlahoda"/>
            <compatibility addition="no" binary="incompatible" deletion="yes" deprecation="yes" modification="no" semantic="incompatible" source="incompatible"/>
            <description>
                Removal of a few obsolete, duplicated and deprecated methods from java/source.
            </description>
            <issue number="106719" />
        </change>
        <change id="JavaSource-Task">
            <api name="general"/>
            <summary>CancellableTask split into Task and CancellableTask.</summary>
            <version major="0" minor="18"/>
            <date day="15" month="6" year="2007"/>
            <author login="tzezula"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                The JavaSource.runModificationTask(), runWhenScanFinished() and runUserActionTask() never call the cancel method of the
                CancellableTask, the implementor of such a CancellableTask just writes an empty cancel method. The compatible API
                change splits the CancellableTask into Task with run method and CancellableTask which extends the Task by cancel method.
                The JavaSource methods mentioned above take Task rather than CancellableTask. The CancellableTask is used only for tasks
                registered by factories.
            </description>
        </change>
        <change id="ClassIndex-interruption">
            <api name="general"/>
            <summary>ClassIndex methods are cancellable</summary>
            <version major="0" minor="16"/>
            <date day="13" month="6" year="2007"/>
            <author login="tzezula"/>
            <compatibility addition="no" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="incompatible" source="compatible"/>
            <description>
                The ClassIndex methods called from the CancellableTask are cancellable. In case when they are cancelled by the JavaSource infrastructure
                they return null instead of the Set to allow client to determine this state. The incompatible semantic change is that tasks registered by
                factories have to check if the value returned from class index is null.
            </description>
        </change>
        <change id="CompilationInfo-getTopLevelElements">
            <api name="general"/>
            <summary>Added a method to obtain top level elements defined in the source/class file.</summary>
            <version major="0" minor="14"/>
            <date day="5" month="6" year="2007"/>
            <author login="tzezula"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                Added a method to obtain top level elements defined in the given source or class file.
            </description>
            <issue number="93100"/>
        </change>
        
        <change id="TreePathHandle-create-Element">
            <api name="general"/>
            <summary>Added factory method which returns a new TreePathHandle for given Element and CompilationInfo.</summary>
            <version major="0" minor="13"/>
            <date day="24" month="4" year="2007"/>
            <author login="jbecicka"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                There is no simple way how to weakly reference all elements from javac. For instance local variables cannot be referenced by
                ElementHandles while source-less Elements cannot be referenced by TreePathHandles. This fix allows to create TreePathHandles 
                for any javac Element (both local and source less).
            </description>
            <issue number="102333"/>
        </change>

        <change id="runWhenScanFinished">
            <api name="general"/>
            <summary>Added a method to run a CancellableTask when the backgound scan is finished.</summary>
            <version major="0" minor="12"/>
            <date day="19" month="4" year="2007"/>
            <author login="tzezula"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                The JavaSource.runWhenScanFinished performs the given task either synchronously when no background scan is running. When the background
                scan is running the task is performed asynchronously when the scan completes.
            </description>
            <issue number="91117"/>
            <issue number="99923"/>
        </change>
        
        <change id="dependent-roots">
            <api name="general"/>
            <summary>Added a method which returns all the project source roots depending on a given source root.</summary>
            <version major="0" minor="10"/>
            <date day="13" month="4" year="2007"/>
            <author login="tzezula"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                The refactoring and find usages need to find the dependent roots of a project root in which the refactored type
                is declared, but finding such an information using the project API may be very expensive especially when lots of
                projects is opened. The goal of this API is to provide and cache this information.
            </description>
            <issue number="92030"/>
        </change>

        <change id="ClassIndexListener">
            <api name="general"/>
            <summary>Added a listener for listening on changes in the <code>ClassIndex</code>.</summary>
            <version major="0" minor="8"/>
            <date day="4" month="4" year="2007"/>
            <author login="tzezula"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                The listener for listening on changes in the <code>ClassIndex</code> was added. The listener fires
                events when a declared type was removed, added, changed in the <code>ClassIndex</code> oe when the underlaying
                <code>ClassPath</code> was changed.
            </description>
            <issue number="91763"/>
        </change>

        <change id="package-property">
            <api name="general"/>
            <summary>Adding template attribute <code>package</code></summary>
            <version major="0" minor="7"/>
            <date day="26" month="3" year="2007"/>
            <author login="jpokorsky"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible"/>
            <description>
                Added the template attribute <code>package</code> for templates using scripting language.
            </description>
            <issue number="95399"/>
        </change>

        <change id="type-utilities">
            <api name="general"/>
            <summary>Removing CommentUtilities, adjusting TreeMaker and introducing TypeUtilities</summary>
            <version major="0" minor="6"/>
            <date day="18" month="3" year="2007"/>
            <author login="jlahoda"/>
            <compatibility addition="yes" binary="compatible" deletion="no" deprecation="no" modification="no" semantic="compatible" source="compatible">
            </compatibility>
            <description>
                <ul>
                    <li>removed org.netbeans.api.java.source.CommentUtilities</li>
                    <li>removed org.netbeans.api.java.source.TreeMaker.Variable(..., TypeElement)</li>
                    <li>removed org.netbeans.api.java.source.TreeMaker.Method(..., TypeElement)</li>
                    <li>added org.netbeans.api.java.source.TypeUtilities</li>
                </ul>
            </description>
            <class package="org.netbeans.api.java.source" name="TypeUtilities"/>
            <issue number="97542"/>
        </change>
        
    </changes>

    <!-- Now the surrounding HTML text and document structure: -->

    <htmlcontents>
<!--

                            NO NO NO NO NO!

         ==============>    DO NOT EDIT ME!  <==============

          AUTOMATICALLY GENERATED FROM APICHANGES.XML, DO NOT EDIT

                SEE CHANGEME/apichanges.xml

-->
    <head>
      <title>Change History for the Java Source API</title>
      <link rel="stylesheet" href="prose.css" type="text/css"/>
    </head>
    <body>

<p class="overviewlink"><a href="overview-summary.html">Overview</a></p>

<h1>Introduction</h1>

<p>This document lists changes made to the <!--<a href="@org-netbeans-modules-java-source@/architecture-summary.html">-->Java Source API<!--</a>-->.</p>

<!-- The actual lists of changes, as summaries and details: -->
      <hr/>
      <standard-changelists module-code-name="org.netbeans.modules.java.source"/>

      <hr/><p>@FOOTER@</p>

    </body>
  </htmlcontents>

</apichanges>