debug printing statistics in console, add removing text method, changed logic of returning to main menu

This commit is contained in:
ZhigalskiiIvan 2023-03-28 20:43:42 +03:00
parent 24438520ea
commit df75f3c99c

View File

@ -14,7 +14,12 @@ object StatisticBuilder {
fun askAndExecuteSelfCommands() { fun askAndExecuteSelfCommands() {
val text = getTextData() ?: return if (!TextData.haveText()) {
println("No saved texts")
return
}
val text = TextData.getTextData("Input name of a text which you want to see statistics about.")
var counter = 1 var counter = 1
val wordsCountsMap = text.getSentencesList().map { counter++ to it.getWordsCount() } val wordsCountsMap = text.getSentencesList().map { counter++ to it.getWordsCount() }
@ -43,25 +48,29 @@ object StatisticBuilder {
} }
private fun printStatisticsInConsole(textName: String, mapOfSentenceNumToItsSize: Map<Int, Int>) { private fun printStatisticsInConsole(textName: String, mapOfSentenceNumToItsSize: Map<Int, Int>) {
println("-".repeat(textName.length)) val sectionTitle = "Text name: $textName"
println("Text name: $textName") println("-".repeat(sectionTitle.length))
println("-".repeat(textName.length)) println(sectionTitle)
println( println("-".repeat(sectionTitle.length))
"Statistics[num of sentence: count of words in it]: ${
mapOfSentenceNumToItsSize.toList().joinToString("; ") { "${it.first}: ${it.second}" } val totalSentencesCount = mapOfSentenceNumToItsSize.size
}.") var totalWordsCount = 0
println("-".repeat(textName.length)) for (sentInfo in mapOfSentenceNumToItsSize) {
println("Done!\n") totalWordsCount += sentInfo.value
} }
println(
private fun getTextData(): TextData.Text? { """
println("Input name of text which you have to get statistics about:") |Statistics:
println("Saved texts: ${TextData.getTextsNamesInString()}") |[count of sentences]:
|--- $totalSentencesCount
val nameRequest = Main.requestInput(TextData.getTextsNamesList()) |[total number of words]:
nameRequest.first.exe() |--- $totalWordsCount
|[num of sentence: count of words in it]:
return TextData.getTextByName(nameRequest.second.toString()) |--- ${mapOfSentenceNumToItsSize.toList().joinToString("; ") { "${it.first} contains ${it.second}" }}.
""".trimMargin()
)
println("-".repeat(sectionTitle.length))
println("Done!\n")
} }
} }
@ -100,7 +109,7 @@ object TextReader {
} }
} else { } else {
itWasNewParYet = false itWasNewParYet = false
content += "\n$nextPart" content += "$nextPart\n"
} }
} }
@ -158,30 +167,59 @@ object TextReader {
object TextData { object TextData {
private val textsList = mutableListOf<Text>() private val textsList = mutableListOf<Text>()
fun getTextByName(searchingName: String): Text? { fun haveText(): Boolean = !textsList.isEmpty()
fun removeText() {
if (!haveText()) {
println("No saved texts")
return
}
val removingText = getTextData("Input name of text which you want to remove.")
textsList.remove(removingText)
println("Text ${removingText.getName()} removed.")
}
private fun getTextByName(searchingName: String): Text? {
for (text in textsList) if (text.getName() == searchingName) return text for (text in textsList) if (text.getName() == searchingName) return text
return null return null
} }
fun getTextsNamesInString(delimiter: String = ", "): String { private fun getTextsNamesInString(delimiter: String = ", "): String {
return textsList.joinToString(delimiter) { it.getName() } return textsList.joinToString(delimiter) { it.getName() }
} }
fun getTextsNamesList(): List<String> { private fun getTextsNamesList(): List<String> {
return textsList.map { it.getName() } return textsList.map { it.getName() }
} }
fun addNewText(textName: String, content: String) { fun addNewText(textName: String, content: String) {
textsList.add(TextAnalyzer.getTextObjFromContents(textName, content)) textsList.add(TextAnalyzer.getTextObjFromContents(textName, content))
} }
fun getTextData(message: String = "Input name of a text"): Text {
println(message)
println("Saved texts: ${getTextsNamesInString()}")
val nameRequest = Main.requestInput(getTextsNamesList())
nameRequest.first.exe()
return getTextByName(nameRequest.second.toString())!!
}
object TextAnalyzer { object TextAnalyzer {
private val DELIMITERS = Regex("[!?.]+\\s+") private val DELIMITERS = Regex("[!?.]+\\s+")
private val WHITESPACES = Regex("\\s+") private val WHITESPACES = Regex("\\s+")
private val WHITESPACES_OR_EMPTY = Regex("(\\s+)?") private val WHITESPACES_OR_EMPTY = Regex("(\\s+)?")
fun getTextObjFromContents(name: String, content: String): Text { fun getTextObjFromContents(name: String, content: String): Text {
var sentencesCount = 0 var sentencesCount = 1
val listOfSentences = mutableListOf<Text.Sentence>() val listOfSentences = mutableListOf<Text.Sentence>()
val sentencesStringList = content val sentencesStringList = content
@ -190,17 +228,18 @@ object TextData {
sentencesStringList.removeIf { it.matches(WHITESPACES_OR_EMPTY) } sentencesStringList.removeIf { it.matches(WHITESPACES_OR_EMPTY) }
for (sentenceText in sentencesStringList) { for (sentenceText in sentencesStringList) {
val wordsList = sentenceText.split(WHITESPACES) val wordsList = sentenceText.split(WHITESPACES).toMutableList()
wordsList.removeIf { it.matches(WHITESPACES_OR_EMPTY) }
sentencesCount++ sentencesCount++
listOfSentences.add(Text.Sentence(wordsList.size)) listOfSentences.add(Text.Sentence(wordsList.size))
} }
return Text(name, sentencesCount, listOfSentences.toList()) return Text(name, sentencesCount, listOfSentences.toList())
} }
} }
data class Text( data class Text(
private val name: String, private val name: String,
private val sentencesCount: Int, private val sentencesCount: Int,
@ -216,7 +255,6 @@ object TextData {
data class Sentence(private val wordsCount: Int) { data class Sentence(private val wordsCount: Int) {
fun getWordsCount() = wordsCount fun getWordsCount() = wordsCount
} }
} }
} }
@ -227,13 +265,14 @@ fun exit(): Nothing {
exitProcess(0) exitProcess(0)
} }
object CommandCenter { object CommandCenter {
private enum class Commands(val executingFun: () -> Unit) { private enum class Commands(val executingFun: () -> Unit) {
EXIT(::exit), EXIT(::exit),
ADD_TEXT({ TextReader.askAndExecuteSelfCommands() }), ADD_TEXT({ TextReader.askAndExecuteSelfCommands() }),
SHOW_STATISTICS({ StatisticBuilder.askAndExecuteSelfCommands() }), SHOW_STATISTICS({ StatisticBuilder.askAndExecuteSelfCommands() }),
REMOVE_TEXT({ println("remove command will be soon") }) REMOVE_TEXT({ TextData.removeText() })
} }
fun readCommandFromConsole(): () -> Unit { fun readCommandFromConsole(): () -> Unit {
@ -246,6 +285,7 @@ object CommandCenter {
return Commands.valueOf(funName).executingFun return Commands.valueOf(funName).executingFun
} }
} }
@ -258,23 +298,35 @@ object ContinueCommand : InputOutcomeCommand {
} }
object ReturnCommand : InputOutcomeCommand { object ReturnCommand : InputOutcomeCommand {
override val exe: () -> Unit = { Main.workCycle() } override val exe: () -> Unit = {
throw ReturnException()
}
} }
class InvalidInputTypeException(expectedType: String) : Exception(expectedType) { class InvalidInputTypeException(expectedType: String) : Exception(expectedType) {
override val message: String = expectedType override val message: String = expectedType
get() = "Was expected type: $field, but it's impossible to convert input in it."
init {
"Was expected type: $message, but it's impossible to convert input in it."
}
} }
class InvalidElemInInputException() : Exception() class InvalidElemInInputException : Exception()
class ReturnException : Exception()
object Main { object Main {
fun workCycle() { fun workCycle() {
mainCycle@ while (true) { mainCycle@ while (true) {
try {
(CommandCenter.readCommandFromConsole())() (CommandCenter.readCommandFromConsole())()
} catch (e: ReturnException) {
println("You have been returned in main menu.")
continue@mainCycle
}
} }
} }
@ -307,21 +359,20 @@ object Main {
return if (availableInputs != null) { return if (availableInputs != null) {
if (inputT.toString() in availableInputs if (inputT.toString() in availableInputs
.map { it.toString() }) Pair(ContinueCommand, inputT) .map { it.toString() }
) Pair(ContinueCommand, inputT)
else throw InvalidElemInInputException() else throw InvalidElemInInputException()
} else Pair(ContinueCommand, inputT) } else Pair(ContinueCommand, inputT)
} catch (e: NumberFormatException) { } catch (e: NumberFormatException) {
println(e.message)
println("")
continue@readingAndChangingTypeCycle continue@readingAndChangingTypeCycle
} catch (e: InvalidInputTypeException) { } catch (e: InvalidInputTypeException) {
println(e.message)
println("")
continue@readingAndChangingTypeCycle continue@readingAndChangingTypeCycle
} catch (e: InvalidElemInInputException) { } catch (e: InvalidElemInInputException) {
println("There isn't this elem in list of available inputs. " + println(
"Try to repeat or enter return to exit in main menu: ") "There isn't this elem in list of available inputs. " +
"Try to repeat or enter return to exit in main menu: "
)
continue@readingAndChangingTypeCycle continue@readingAndChangingTypeCycle
} }
} }