:PROPERTIES: :ID: bb4f96cd-458c-495b-a605-313b2e3e28d2 :END: #+TITLE: CLI Helper - library to help implementing commandline interfaces * General - This program is free software: released under Creative Commons Zero (CC0) license - Program author: - Svjatoslav Agejenko - Homepage: https://svjatoslav.eu - Email: mailto://svjatoslav@svjatoslav.eu - [[https://www.svjatoslav.eu/projects/][Other software projects hosted at svjatoslav.eu]] ** Source code - [[https://www2.svjatoslav.eu/gitweb/?p=cli-helper.git;a=snapshot;h=HEAD;sf=tgz][Download latest snapshot in TAR GZ format]] - [[https://www2.svjatoslav.eu/gitweb/?p=cli-helper.git;a=summary][Browse Git repository online]] - Clone Git repository using command: : git clone https://www2.svjatoslav.eu/git/cli-helper.git - See [[https://www3.svjatoslav.eu/projects/cli-helper/apidocs/][JavaDoc]] * Overview :PROPERTIES: :ID: fef7ebc3-0f00-4b82-a926-c0cfdf709762 :END: - See also: [[https://www3.svjatoslav.eu/projects/svjatoslav_commons/apidocs/][CLI Helper JavaDoc]]. This is library intended to facilitate creation of commandline applications in Java programming language. Library is packaged as an artifact to Maven repository. This makes it simple to add library as dependency to your project. Library provides following general functionalities: - [[id:4fca35e4-fdf1-4675-a36f-6206d6fb72cb][Asking for user input]] - [[id:46115263-ed3d-4acc-9ec5-523d7acf87b8][Commandline arguments processing]] ** Ask for user input :PROPERTIES: :ID: 4fca35e4-fdf1-4675-a36f-6206d6fb72cb :END: - askBoolean() :: Asks the user to enter a boolean value (yes/no). - askLong() :: Asks the user to enter an integer. - askString() :: Asks the user to enter a string. * Getting the library Instructions to embed svjatoslav-commons library in your project: Maven pom.xml file snippet: #+BEGIN_SRC xml ... eu.svjatoslav cli-helper 1.0 ... ... svjatoslav.eu Svjatoslav repository http://www3.svjatoslav.eu/maven/ ... #+END_SRC * TODO: List of improvement suggestions: - Add more concrete examples of how to use the library in JavaDoc comments. This will help developers quickly get started and learn the API. - Provide more comprehensive unit tests for CliHelper, ParameterParser, Options and subclasses. This will ensure robustness and stability. - Add JavaDoc comments to all classes and methods where applicable. This will provide better visibility into the library's functionality for developers. - Add more option types like date/time, regular expression etc. - Document best practices for using the library in a larger project. - Implement support for more complex CLI applications like option dependencies and conflicts resolution.