2023-04-05 14:39:51 +00:00

298 lines
6.2 KiB
Java

/*
* Copyright (c) 2015, 2022, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 8144287 8273244 8284908 8305620
* @summary extend com.sun.source API to support parsing javadoc comments
* @modules jdk.compiler/com.sun.tools.javac.api
* jdk.compiler/com.sun.tools.javac.file
* jdk.compiler/com.sun.tools.javac.tree
* jdk.compiler/com.sun.tools.javac.util
* @build DocCommentTester
* @run main DocCommentTester IndexTest.java
*/
class IndexTest {
/**
* abc {@index xyz} def
*/
void simple_term() {}
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 3
Text[TEXT, pos:1, abc_]
Index[INDEX, pos:5
term:
Text[TEXT, pos:13, xyz]
description: empty
]
Text[TEXT, pos:17, _def]
body: empty
block tags: empty
]
*/
/**
* abc {@index lmn pqr stu} def
*/
void simple_term_with_description() { }
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 3
Text[TEXT, pos:1, abc_]
Index[INDEX, pos:5
term:
Text[TEXT, pos:13, lmn]
description: 1
Text[TEXT, pos:17, pqr_stu]
]
Text[TEXT, pos:25, _def]
body: empty
block tags: empty
]
*/
/**
* abc {@index ijk {lmn opq} } def
*/
void phrase_with_curly_description() { }
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 3
Text[TEXT, pos:1, abc_]
Index[INDEX, pos:5
term:
Text[TEXT, pos:13, ijk]
description: 1
Text[TEXT, pos:17, {lmn_opq}_]
]
Text[TEXT, pos:28, _def]
body: empty
block tags: empty
]
*/
/**
* abc {@index ijk lmn
* opq
* rst
* } def
*/
void phrase_with_nl_description() { }
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 3
Text[TEXT, pos:1, abc_]
Index[INDEX, pos:5
term:
Text[TEXT, pos:13, ijk]
description: 1
Text[TEXT, pos:17, lmn|_opq|_rst|_]
]
Text[TEXT, pos:33, _def]
body: empty
block tags: empty
]
*/
/**
* abc {@index "lmn pqr"} def
*/
void phrase_no_description() { }
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 3
Text[TEXT, pos:1, abc_]
Index[INDEX, pos:5
term:
Text[TEXT, pos:13, "lmn_pqr"]
description: empty
]
Text[TEXT, pos:23, _def]
body: empty
block tags: empty
]
*/
/**
* abc {@index "ijk lmn" pqr xyz} def
*/
void phrase_with_description() { }
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 3
Text[TEXT, pos:1, abc_]
Index[INDEX, pos:5
term:
Text[TEXT, pos:13, "ijk_lmn"]
description: 1
Text[TEXT, pos:23, pqr_xyz]
]
Text[TEXT, pos:31, _def]
body: empty
block tags: empty
]
*/
/**
* abc {@index {@xyz} "{@see xyz}"} def
*/
void term_and_description_with_nested_tag() {}
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 3
Text[TEXT, pos:1, abc_]
Index[INDEX, pos:5
term:
Text[TEXT, pos:13, {@xyz}]
description: 3
Text[TEXT, pos:20, "]
UnknownInlineTag[UNKNOWN_INLINE_TAG, pos:21
tag:see
content: 1
Text[TEXT, pos:27, xyz]
]
Text[TEXT, pos:31, "]
]
Text[TEXT, pos:33, _def]
body: empty
block tags: empty
]
*/
/**
* abc {@index @def lmn } xyz
*/
void term_with_at() { }
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 3
Text[TEXT, pos:1, abc_]
Index[INDEX, pos:5
term:
Text[TEXT, pos:13, @def]
description: 1
Text[TEXT, pos:18, lmn_]
]
Text[TEXT, pos:23, _xyz]
body: empty
block tags: empty
]
*/
/**
* abc {@index ijk@lmn pqr } xyz
*/
void term_with_text_at() { }
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 3
Text[TEXT, pos:1, abc_]
Index[INDEX, pos:5
term:
Text[TEXT, pos:13, ijk@lmn]
description: 1
Text[TEXT, pos:21, pqr_]
]
Text[TEXT, pos:26, _xyz]
body: empty
block tags: empty
]
*/
/**
* abc {@index ""} def
*/
void empty_index_in_quotes() {}
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 3
Text[TEXT, pos:1, abc_]
Index[INDEX, pos:5
term:
Text[TEXT, pos:13, ""]
description: empty
]
Text[TEXT, pos:16, _def]
body: empty
block tags: empty
]
*/
/**
* abc {@index
* @return def} xyz
*/
@NormalizeTags(false) // see DocCommentTester.PrettyChecker
void bad_nl_at_in_term() {}
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 2
Text[TEXT, pos:1, abc_]
Erroneous[ERRONEOUS, pos:5, prefPos:11
code: compiler.err.dc.no.content
body: {@index
]
body: empty
block tags: 1
Return[RETURN, pos:14
description: 1
Text[TEXT, pos:22, def}_xyz]
]
]
*/
/**
* abc {@index "xyz } def
*/
void bad_unbalanced_quote() {}
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 2
Text[TEXT, pos:1, abc_]
Erroneous[ERRONEOUS, pos:5, prefPos:22
code: compiler.err.dc.no.content
body: {@index_"xyz_}_def
]
body: empty
block tags: empty
]
*/
/**
* abc {@index} def
*/
void bad_no_index() {}
/*
DocComment[DOC_COMMENT, pos:1
firstSentence: 3
Text[TEXT, pos:1, abc_]
Erroneous[ERRONEOUS, pos:5, prefPos:11
code: compiler.err.dc.no.content
body: {@index
]
Text[TEXT, pos:12, }_def]
body: empty
block tags: empty
]
*/
}