Compare commits

..

No commits in common. "0.17" and "0.4" have entirely different histories.
0.17 ... 0.4

61 changed files with 220 additions and 284 deletions

View file

@ -2,21 +2,21 @@
<classpath> <classpath>
<classpathentry kind="src" path="src"/> <classpathentry kind="src" path="src"/>
<classpathentry kind="src" path="test"/> <classpathentry kind="src" path="test"/>
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-17"> <classpathentry kind="con" path="org.eclipse.jst.j2ee.internal.module.container"/>
<classpathentry kind="lib" path="lib/commons-lang3-3.1.jar" sourcepath="lib/commons-lang3-3.1-sources.jar"/>
<classpathentry kind="lib" path="lib/joda-time-2.3.jar" sourcepath="lib/joda-time-2.3-sources.jar"/>
<classpathentry kind="lib" path="lib/devinsy-strings-0.4.0.jar" sourcepath="lib/devinsy-strings-0.4.0-sources.zip"/>
<classpathentry kind="lib" path="lib/Logs/log4j-1.2.17.jar" sourcepath="lib/Logs/log4j-1.2.17-source.zip"/>
<classpathentry kind="lib" path="lib/Logs/slf4j-api-1.7.5.jar" sourcepath="lib/Logs/slf4j-api-1.7.5-sources.jar"/>
<classpathentry kind="lib" path="lib/Logs/slf4j-log4j12-1.7.5.jar" sourcepath="lib/Logs/slf4j-log4j12-1.7.5-sources.jar"/>
<classpathentry kind="lib" path="lib/UnitTesting/hamcrest-core-1.3.jar" sourcepath="lib/UnitTesting/hamcrest-core-1.3-sources.jar"/>
<classpathentry kind="lib" path="lib/UnitTesting/junit-4.11.jar" sourcepath="lib/UnitTesting/junit-4.11-sources.jar"/>
<classpathentry kind="lib" path="lib/devinsy-cmdexec-0.4.1.jar" sourcepath="lib/devinsy-cmdexec-0.4.1-sources.zip"/>
<classpathentry kind="lib" path="lib/commons-io-2.5.jar" sourcepath="lib/commons-io-2.5-src.jar"/>
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.6">
<attributes> <attributes>
<attribute name="module" value="true"/>
<attribute name="owner.project.facets" value="java"/> <attribute name="owner.project.facets" value="java"/>
</attributes> </attributes>
</classpathentry> </classpathentry>
<classpathentry kind="con" path="org.eclipse.jst.j2ee.internal.module.container"/>
<classpathentry kind="lib" path="lib/Logs/log4j-1.2.17.jar" sourcepath="lib/Logs/log4j-1.2.17-source.zip"/>
<classpathentry kind="lib" path="lib/UnitTesting/hamcrest-core-1.3.jar" sourcepath="lib/UnitTesting/hamcrest-core-1.3-sources.jar"/>
<classpathentry kind="lib" path="lib/Logs/slf4j-api-1.7.25.jar" sourcepath="lib/Logs/slf4j-api-1.7.25-sources.jar"/>
<classpathentry kind="lib" path="lib/Logs/slf4j-log4j12-1.7.25.jar" sourcepath="lib/Logs/slf4j-log4j12-1.7.25-sources.jar"/>
<classpathentry kind="lib" path="lib/UnitTesting/junit-4.12.jar" sourcepath="lib/Logs/log4j-1.2.17-source.zip"/>
<classpathentry kind="lib" path="lib/commons-io-2.11.0.jar" sourcepath="lib/commons-io-2.11.0-sources.jar"/>
<classpathentry kind="lib" path="lib/commons-lang3-3.12.0.jar" sourcepath="lib/commons-lang3-3.12.0-sources.jar"/>
<classpathentry kind="lib" path="lib/devinsy-cmdexec-0.17.0.jar" sourcepath="lib/devinsy-cmdexec-0.17.0-sources.zip"/>
<classpathentry kind="lib" path="lib/devinsy-strings-0.17.0.jar" sourcepath="lib/devinsy-strings-0.17.0-sources.zip"/>
<classpathentry kind="output" path="bin"/> <classpathentry kind="output" path="bin"/>
</classpath> </classpath>

View file

@ -10,20 +10,16 @@ org.eclipse.jdt.core.codeComplete.staticFieldSuffixes=
org.eclipse.jdt.core.codeComplete.staticFinalFieldPrefixes= org.eclipse.jdt.core.codeComplete.staticFinalFieldPrefixes=
org.eclipse.jdt.core.codeComplete.staticFinalFieldSuffixes= org.eclipse.jdt.core.codeComplete.staticFinalFieldSuffixes=
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
org.eclipse.jdt.core.compiler.codegen.targetPlatform=17 org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.6
org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve
org.eclipse.jdt.core.compiler.compliance=17 org.eclipse.jdt.core.compiler.compliance=1.6
org.eclipse.jdt.core.compiler.debug.lineNumber=generate org.eclipse.jdt.core.compiler.debug.lineNumber=generate
org.eclipse.jdt.core.compiler.debug.localVariable=generate org.eclipse.jdt.core.compiler.debug.localVariable=generate
org.eclipse.jdt.core.compiler.debug.sourceFile=generate org.eclipse.jdt.core.compiler.debug.sourceFile=generate
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
org.eclipse.jdt.core.compiler.problem.enablePreviewFeatures=disabled
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
org.eclipse.jdt.core.compiler.problem.reportPreviewFeatures=warning org.eclipse.jdt.core.compiler.source=1.6
org.eclipse.jdt.core.compiler.release=enabled
org.eclipse.jdt.core.compiler.source=17
org.eclipse.jdt.core.formatter.align_type_members_on_columns=false org.eclipse.jdt.core.formatter.align_type_members_on_columns=false
org.eclipse.jdt.core.formatter.alignment_for_additive_operator=16
org.eclipse.jdt.core.formatter.alignment_for_arguments_in_allocation_expression=16 org.eclipse.jdt.core.formatter.alignment_for_arguments_in_allocation_expression=16
org.eclipse.jdt.core.formatter.alignment_for_arguments_in_annotation=0 org.eclipse.jdt.core.formatter.alignment_for_arguments_in_annotation=0
org.eclipse.jdt.core.formatter.alignment_for_arguments_in_enum_constant=16 org.eclipse.jdt.core.formatter.alignment_for_arguments_in_enum_constant=16
@ -31,20 +27,17 @@ org.eclipse.jdt.core.formatter.alignment_for_arguments_in_explicit_constructor_c
org.eclipse.jdt.core.formatter.alignment_for_arguments_in_method_invocation=16 org.eclipse.jdt.core.formatter.alignment_for_arguments_in_method_invocation=16
org.eclipse.jdt.core.formatter.alignment_for_arguments_in_qualified_allocation_expression=16 org.eclipse.jdt.core.formatter.alignment_for_arguments_in_qualified_allocation_expression=16
org.eclipse.jdt.core.formatter.alignment_for_assignment=0 org.eclipse.jdt.core.formatter.alignment_for_assignment=0
org.eclipse.jdt.core.formatter.alignment_for_bitwise_operator=16 org.eclipse.jdt.core.formatter.alignment_for_binary_expression=16
org.eclipse.jdt.core.formatter.alignment_for_compact_if=16 org.eclipse.jdt.core.formatter.alignment_for_compact_if=16
org.eclipse.jdt.core.formatter.alignment_for_conditional_expression=80 org.eclipse.jdt.core.formatter.alignment_for_conditional_expression=80
org.eclipse.jdt.core.formatter.alignment_for_enum_constants=49 org.eclipse.jdt.core.formatter.alignment_for_enum_constants=49
org.eclipse.jdt.core.formatter.alignment_for_expressions_in_array_initializer=16 org.eclipse.jdt.core.formatter.alignment_for_expressions_in_array_initializer=16
org.eclipse.jdt.core.formatter.alignment_for_logical_operator=16
org.eclipse.jdt.core.formatter.alignment_for_method_declaration=0 org.eclipse.jdt.core.formatter.alignment_for_method_declaration=0
org.eclipse.jdt.core.formatter.alignment_for_multiple_fields=16 org.eclipse.jdt.core.formatter.alignment_for_multiple_fields=16
org.eclipse.jdt.core.formatter.alignment_for_multiplicative_operator=16
org.eclipse.jdt.core.formatter.alignment_for_parameters_in_constructor_declaration=16 org.eclipse.jdt.core.formatter.alignment_for_parameters_in_constructor_declaration=16
org.eclipse.jdt.core.formatter.alignment_for_parameters_in_method_declaration=16 org.eclipse.jdt.core.formatter.alignment_for_parameters_in_method_declaration=16
org.eclipse.jdt.core.formatter.alignment_for_resources_in_try=80 org.eclipse.jdt.core.formatter.alignment_for_resources_in_try=80
org.eclipse.jdt.core.formatter.alignment_for_selector_in_method_invocation=16 org.eclipse.jdt.core.formatter.alignment_for_selector_in_method_invocation=16
org.eclipse.jdt.core.formatter.alignment_for_string_concatenation=16
org.eclipse.jdt.core.formatter.alignment_for_superclass_in_type_declaration=16 org.eclipse.jdt.core.formatter.alignment_for_superclass_in_type_declaration=16
org.eclipse.jdt.core.formatter.alignment_for_superinterfaces_in_enum_declaration=16 org.eclipse.jdt.core.formatter.alignment_for_superinterfaces_in_enum_declaration=16
org.eclipse.jdt.core.formatter.alignment_for_superinterfaces_in_type_declaration=16 org.eclipse.jdt.core.formatter.alignment_for_superinterfaces_in_type_declaration=16
@ -128,12 +121,11 @@ org.eclipse.jdt.core.formatter.insert_new_line_in_empty_enum_constant=insert
org.eclipse.jdt.core.formatter.insert_new_line_in_empty_enum_declaration=insert org.eclipse.jdt.core.formatter.insert_new_line_in_empty_enum_declaration=insert
org.eclipse.jdt.core.formatter.insert_new_line_in_empty_method_body=insert org.eclipse.jdt.core.formatter.insert_new_line_in_empty_method_body=insert
org.eclipse.jdt.core.formatter.insert_new_line_in_empty_type_declaration=insert org.eclipse.jdt.core.formatter.insert_new_line_in_empty_type_declaration=insert
org.eclipse.jdt.core.formatter.insert_space_after_additive_operator=insert
org.eclipse.jdt.core.formatter.insert_space_after_and_in_type_parameter=insert org.eclipse.jdt.core.formatter.insert_space_after_and_in_type_parameter=insert
org.eclipse.jdt.core.formatter.insert_space_after_assignment_operator=insert org.eclipse.jdt.core.formatter.insert_space_after_assignment_operator=insert
org.eclipse.jdt.core.formatter.insert_space_after_at_in_annotation=do not insert org.eclipse.jdt.core.formatter.insert_space_after_at_in_annotation=do not insert
org.eclipse.jdt.core.formatter.insert_space_after_at_in_annotation_type_declaration=do not insert org.eclipse.jdt.core.formatter.insert_space_after_at_in_annotation_type_declaration=do not insert
org.eclipse.jdt.core.formatter.insert_space_after_bitwise_operator=insert org.eclipse.jdt.core.formatter.insert_space_after_binary_operator=insert
org.eclipse.jdt.core.formatter.insert_space_after_closing_angle_bracket_in_type_arguments=insert org.eclipse.jdt.core.formatter.insert_space_after_closing_angle_bracket_in_type_arguments=insert
org.eclipse.jdt.core.formatter.insert_space_after_closing_angle_bracket_in_type_parameters=insert org.eclipse.jdt.core.formatter.insert_space_after_closing_angle_bracket_in_type_parameters=insert
org.eclipse.jdt.core.formatter.insert_space_after_closing_brace_in_block=insert org.eclipse.jdt.core.formatter.insert_space_after_closing_brace_in_block=insert
@ -163,8 +155,6 @@ org.eclipse.jdt.core.formatter.insert_space_after_comma_in_superinterfaces=inser
org.eclipse.jdt.core.formatter.insert_space_after_comma_in_type_arguments=insert org.eclipse.jdt.core.formatter.insert_space_after_comma_in_type_arguments=insert
org.eclipse.jdt.core.formatter.insert_space_after_comma_in_type_parameters=insert org.eclipse.jdt.core.formatter.insert_space_after_comma_in_type_parameters=insert
org.eclipse.jdt.core.formatter.insert_space_after_ellipsis=insert org.eclipse.jdt.core.formatter.insert_space_after_ellipsis=insert
org.eclipse.jdt.core.formatter.insert_space_after_logical_operator=insert
org.eclipse.jdt.core.formatter.insert_space_after_multiplicative_operator=insert
org.eclipse.jdt.core.formatter.insert_space_after_opening_angle_bracket_in_parameterized_type_reference=do not insert org.eclipse.jdt.core.formatter.insert_space_after_opening_angle_bracket_in_parameterized_type_reference=do not insert
org.eclipse.jdt.core.formatter.insert_space_after_opening_angle_bracket_in_type_arguments=do not insert org.eclipse.jdt.core.formatter.insert_space_after_opening_angle_bracket_in_type_arguments=do not insert
org.eclipse.jdt.core.formatter.insert_space_after_opening_angle_bracket_in_type_parameters=do not insert org.eclipse.jdt.core.formatter.insert_space_after_opening_angle_bracket_in_type_parameters=do not insert
@ -189,17 +179,13 @@ org.eclipse.jdt.core.formatter.insert_space_after_postfix_operator=do not insert
org.eclipse.jdt.core.formatter.insert_space_after_prefix_operator=do not insert org.eclipse.jdt.core.formatter.insert_space_after_prefix_operator=do not insert
org.eclipse.jdt.core.formatter.insert_space_after_question_in_conditional=insert org.eclipse.jdt.core.formatter.insert_space_after_question_in_conditional=insert
org.eclipse.jdt.core.formatter.insert_space_after_question_in_wildcard=do not insert org.eclipse.jdt.core.formatter.insert_space_after_question_in_wildcard=do not insert
org.eclipse.jdt.core.formatter.insert_space_after_relational_operator=insert
org.eclipse.jdt.core.formatter.insert_space_after_semicolon_in_for=insert org.eclipse.jdt.core.formatter.insert_space_after_semicolon_in_for=insert
org.eclipse.jdt.core.formatter.insert_space_after_semicolon_in_try_resources=insert org.eclipse.jdt.core.formatter.insert_space_after_semicolon_in_try_resources=insert
org.eclipse.jdt.core.formatter.insert_space_after_shift_operator=insert
org.eclipse.jdt.core.formatter.insert_space_after_string_concatenation=insert
org.eclipse.jdt.core.formatter.insert_space_after_unary_operator=do not insert org.eclipse.jdt.core.formatter.insert_space_after_unary_operator=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_additive_operator=insert
org.eclipse.jdt.core.formatter.insert_space_before_and_in_type_parameter=insert org.eclipse.jdt.core.formatter.insert_space_before_and_in_type_parameter=insert
org.eclipse.jdt.core.formatter.insert_space_before_assignment_operator=insert org.eclipse.jdt.core.formatter.insert_space_before_assignment_operator=insert
org.eclipse.jdt.core.formatter.insert_space_before_at_in_annotation_type_declaration=insert org.eclipse.jdt.core.formatter.insert_space_before_at_in_annotation_type_declaration=insert
org.eclipse.jdt.core.formatter.insert_space_before_bitwise_operator=insert org.eclipse.jdt.core.formatter.insert_space_before_binary_operator=insert
org.eclipse.jdt.core.formatter.insert_space_before_closing_angle_bracket_in_parameterized_type_reference=do not insert org.eclipse.jdt.core.formatter.insert_space_before_closing_angle_bracket_in_parameterized_type_reference=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_closing_angle_bracket_in_type_arguments=do not insert org.eclipse.jdt.core.formatter.insert_space_before_closing_angle_bracket_in_type_arguments=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_closing_angle_bracket_in_type_parameters=do not insert org.eclipse.jdt.core.formatter.insert_space_before_closing_angle_bracket_in_type_parameters=do not insert
@ -246,8 +232,6 @@ org.eclipse.jdt.core.formatter.insert_space_before_comma_in_superinterfaces=do n
org.eclipse.jdt.core.formatter.insert_space_before_comma_in_type_arguments=do not insert org.eclipse.jdt.core.formatter.insert_space_before_comma_in_type_arguments=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_comma_in_type_parameters=do not insert org.eclipse.jdt.core.formatter.insert_space_before_comma_in_type_parameters=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_ellipsis=do not insert org.eclipse.jdt.core.formatter.insert_space_before_ellipsis=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_logical_operator=insert
org.eclipse.jdt.core.formatter.insert_space_before_multiplicative_operator=insert
org.eclipse.jdt.core.formatter.insert_space_before_opening_angle_bracket_in_parameterized_type_reference=do not insert org.eclipse.jdt.core.formatter.insert_space_before_opening_angle_bracket_in_parameterized_type_reference=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_opening_angle_bracket_in_type_arguments=do not insert org.eclipse.jdt.core.formatter.insert_space_before_opening_angle_bracket_in_type_arguments=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_opening_angle_bracket_in_type_parameters=do not insert org.eclipse.jdt.core.formatter.insert_space_before_opening_angle_bracket_in_type_parameters=do not insert
@ -284,12 +268,9 @@ org.eclipse.jdt.core.formatter.insert_space_before_postfix_operator=do not inser
org.eclipse.jdt.core.formatter.insert_space_before_prefix_operator=do not insert org.eclipse.jdt.core.formatter.insert_space_before_prefix_operator=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_question_in_conditional=insert org.eclipse.jdt.core.formatter.insert_space_before_question_in_conditional=insert
org.eclipse.jdt.core.formatter.insert_space_before_question_in_wildcard=do not insert org.eclipse.jdt.core.formatter.insert_space_before_question_in_wildcard=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_relational_operator=insert
org.eclipse.jdt.core.formatter.insert_space_before_semicolon=do not insert org.eclipse.jdt.core.formatter.insert_space_before_semicolon=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_semicolon_in_for=do not insert org.eclipse.jdt.core.formatter.insert_space_before_semicolon_in_for=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_semicolon_in_try_resources=do not insert org.eclipse.jdt.core.formatter.insert_space_before_semicolon_in_try_resources=do not insert
org.eclipse.jdt.core.formatter.insert_space_before_shift_operator=insert
org.eclipse.jdt.core.formatter.insert_space_before_string_concatenation=insert
org.eclipse.jdt.core.formatter.insert_space_before_unary_operator=do not insert org.eclipse.jdt.core.formatter.insert_space_before_unary_operator=do not insert
org.eclipse.jdt.core.formatter.insert_space_between_brackets_in_array_type_reference=do not insert org.eclipse.jdt.core.formatter.insert_space_between_brackets_in_array_type_reference=do not insert
org.eclipse.jdt.core.formatter.insert_space_between_empty_braces_in_array_initializer=do not insert org.eclipse.jdt.core.formatter.insert_space_between_empty_braces_in_array_initializer=do not insert
@ -315,10 +296,6 @@ org.eclipse.jdt.core.formatter.tabulation.char=tab
org.eclipse.jdt.core.formatter.tabulation.size=4 org.eclipse.jdt.core.formatter.tabulation.size=4
org.eclipse.jdt.core.formatter.use_on_off_tags=false org.eclipse.jdt.core.formatter.use_on_off_tags=false
org.eclipse.jdt.core.formatter.use_tabs_only_for_leading_indentations=false org.eclipse.jdt.core.formatter.use_tabs_only_for_leading_indentations=false
org.eclipse.jdt.core.formatter.wrap_before_additive_operator=true org.eclipse.jdt.core.formatter.wrap_before_binary_operator=true
org.eclipse.jdt.core.formatter.wrap_before_bitwise_operator=true
org.eclipse.jdt.core.formatter.wrap_before_logical_operator=true
org.eclipse.jdt.core.formatter.wrap_before_multiplicative_operator=true
org.eclipse.jdt.core.formatter.wrap_before_or_operator_multicatch=true org.eclipse.jdt.core.formatter.wrap_before_or_operator_multicatch=true
org.eclipse.jdt.core.formatter.wrap_before_string_concatenation=true
org.eclipse.jdt.core.formatter.wrap_outer_expressions_when_nested=true org.eclipse.jdt.core.formatter.wrap_outer_expressions_when_nested=true

View file

@ -2,6 +2,6 @@
<faceted-project> <faceted-project>
<fixed facet="jst.java"/> <fixed facet="jst.java"/>
<fixed facet="jst.utility"/> <fixed facet="jst.utility"/>
<installed facet="jst.java" version="6.0"/>
<installed facet="jst.utility" version="1.0"/> <installed facet="jst.utility" version="1.0"/>
<installed facet="jst.java" version="17"/>
</faceted-project> </faceted-project>

View file

@ -11,8 +11,8 @@ This software is released under the GNU LGPL.
## Requirements ## Requirements
- Java 11 - Java 1.6
- Eclipse 4.16 (202006). - Eclipse Kepler
## Context ## Context
Several useful Java classes. Several useful Java classes.

View file

@ -1,3 +1,3 @@
#Build Number for ANT. Do not edit! #Build Number for ANT. Do not edit!
#Thu Oct 14 18:12:14 CEST 2021 #Thu May 04 22:58:25 CEST 2017
build.number=1 build.number=1

View file

@ -1,3 +1,3 @@
product.name=devinsy-unix product.name=devinsy-unix
product.revision.major=0 product.revision.major=0
product.revision.minor=17 product.revision.minor=4

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

View file

@ -1,17 +1,9 @@
== Description of used libraries. Description of used libraries:
- commons-lang: useful tools (StringUtils...)
Standards: - hamcrest-core: required by junit
- commons-io - joda-time: useful DateTime library
- commons-lang: useful tools (StringUtils…) - junit: unit tests API
- devinsy-strings
- devinsy-cmdexec
Logging:
- log4j: log API - log4j: log API
- slf4j-api: facade log API - slf4j-api: facade log API
- slf4j-log4j12: adaptation layer between slf4j and log4j - slf4j-log4j12: adaptation layer between slf4j and log4j
Testing:
- hamcrest-core: required by JUnit
- junit: unit tests API

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

BIN
lib/commons-io-2.5-src.jar Normal file

Binary file not shown.

BIN
lib/commons-io-2.5.jar Normal file

Binary file not shown.

Binary file not shown.

BIN
lib/commons-lang3-3.1.jar Normal file

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

BIN
lib/joda-time-2.3.jar Normal file

Binary file not shown.

3
src/META-INF/MANIFEST.MF Normal file
View file

@ -0,0 +1,3 @@
Manifest-Version: 1.0
Class-Path:

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2006-2021 Christian Pierre MOMON * Copyright (C) 2006-2010,2013-2014,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,15 +16,23 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix.util; package fr.devinsy.util;
import java.io.File; import java.io.File;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/** /**
* The Class ChangeableFile. * The Class CachedFile.
*
* @author Christian Pierre MOMON <christian.momon@devinsy.fr>
*/ */
public class ChangeableFile public class ChangeableFile
{ {
private static final Logger logger = LoggerFactory.getLogger(ChangeableFile.class);
private File sourceFile; private File sourceFile;
private long sourceTime; private long sourceTime;
@ -111,3 +119,5 @@ public class ChangeableFile
this.sourceTime = 0; this.sourceTime = 0;
} }
} }
// ////////////////////////////////////////////////////////////////////////

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2017-2021 Christian Pierre MOMON * Copyright (C) 2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix.util; package fr.devinsy.util;
/** /**
* The Class Property. * The Class Property.
@ -28,11 +28,6 @@ public class Property
/** /**
* Utility class has not to have a constructor. * Utility class has not to have a constructor.
*
* @param name
* the name
* @param value
* the value
*/ */
public Property(final String name, final String value) public Property(final String name, final String value)
{ {
@ -40,43 +35,21 @@ public class Property
this.value = value; this.value = value;
} }
/**
* Gets the name.
*
* @return the name
*/
public String getName() public String getName()
{ {
return this.name; return this.name;
} }
/**
* Gets the value.
*
* @return the value
*/
public String getValue() public String getValue()
{ {
return this.value; return this.value;
} }
/**
* Sets the name.
*
* @param name
* the new name
*/
public void setName(final String name) public void setName(final String name)
{ {
this.name = name; this.name = name;
} }
/**
* Sets the value.
*
* @param value
* the new value
*/
public void setValue(final String value) public void setValue(final String value)
{ {
this.value = value; this.value = value;

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2017-2018 Christian Pierre MOMON * Copyright (C) 2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix.util; package fr.devinsy.util;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections; import java.util.Collections;

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2006-2010,2013-2014,2017-2018 Christian Pierre MOMON * Copyright (C) 2006-2010,2013-2014,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,11 +16,11 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix; package fr.devinsy.util.unix;
import java.util.Vector; import java.util.Vector;
import fr.devinsy.unix.util.ChangeableFile; import fr.devinsy.util.ChangeableFile;
/** /**
* The Class EtcGroupFile. * The Class EtcGroupFile.
@ -144,8 +144,10 @@ public class EtcGroupFile extends ChangeableFile
return result; return result;
} }
/* (non-Javadoc) /**
* @see fr.devinsy.unix.util.ChangeableFile#refresh() * This method returns the updated groups.
*
* @return the groups
*/ */
@Override @Override
public void refresh() public void refresh()

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2006-2021 Christian Pierre MOMON * Copyright (C) 2006-2010,2013-2014,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix; package fr.devinsy.util.unix;
import java.io.BufferedReader; import java.io.BufferedReader;
import java.io.FileReader; import java.io.FileReader;
@ -65,7 +65,7 @@ public class EtcGroupFileReader
Group group = new Group(); Group group = new Group();
group.setName(tokens[0]); group.setName(tokens[0]);
group.setPassword(tokens[1]); group.setPassword(tokens[1]);
group.setGid(Integer.valueOf(tokens[2]).intValue()); group.setGid((new Integer(tokens[2])).intValue());
// Manage the case of empty shell. // Manage the case of empty shell.
if (tokens.length == 4) if (tokens.length == 4)
@ -105,3 +105,5 @@ public class EtcGroupFileReader
return result; return result;
} }
} }
// ////////////////////////////////////////////////////////////////////////

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2006-2021 Christian Pierre MOMON * Copyright (C) 2006-2010,2013-2014,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,12 +16,17 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix; package fr.devinsy.util.unix;
import fr.devinsy.unix.util.ChangeableFile; import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import fr.devinsy.util.ChangeableFile;
/** /**
* The Class EtcPasswdFile. * The Class EtcPasswdFile.
*
* @author Christian Pierre MOMON (christian.momon@devinsy.fr)
*/ */
public class EtcPasswdFile extends ChangeableFile public class EtcPasswdFile extends ChangeableFile
{ {
@ -31,6 +36,8 @@ public class EtcPasswdFile extends ChangeableFile
private static final EtcPasswdFile instance = new EtcPasswdFile(); private static final EtcPasswdFile instance = new EtcPasswdFile();
} }
private static final Logger logger = LoggerFactory.getLogger(EtcPasswdFile.class);
private Users users; private Users users;
/** /**
@ -99,8 +106,10 @@ public class EtcPasswdFile extends ChangeableFile
return result; return result;
} }
/* (non-Javadoc) /**
* @see fr.devinsy.unix.util.ChangeableFile#refresh() * Updated users.
*
* @return the users
*/ */
@Override @Override
public void refresh() public void refresh()
@ -143,3 +152,5 @@ public class EtcPasswdFile extends ChangeableFile
return result; return result;
} }
} }
// ////////////////////////////////////////////////////////////////////////

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2006-2021 Christian Pierre MOMON * Copyright (C) 2006-2010,2013-2014,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix; package fr.devinsy.util.unix;
import java.io.BufferedReader; import java.io.BufferedReader;
import java.io.FileReader; import java.io.FileReader;
@ -28,6 +28,7 @@ import org.slf4j.LoggerFactory;
/** /**
* The Class EtcPasswdFileReader. * The Class EtcPasswdFileReader.
* *
* @author Christian Pierre MOMON (christian.momon@devinsy.fr)
*/ */
public class EtcPasswdFileReader public class EtcPasswdFileReader
{ {
@ -65,8 +66,8 @@ public class EtcPasswdFileReader
User user = new User(); User user = new User();
user.setLogin(tokens[0]); user.setLogin(tokens[0]);
user.setPassword(tokens[1]); user.setPassword(tokens[1]);
user.setUid(Integer.valueOf(tokens[2]).intValue()); user.setUid((new Integer(tokens[2])).intValue());
user.setGid(Integer.valueOf(tokens[3]).intValue()); user.setGid((new Integer(tokens[3])).intValue());
user.setRealName(tokens[4]); user.setRealName(tokens[4]);
user.setHomeDirectory(tokens[5]); user.setHomeDirectory(tokens[5]);
@ -108,3 +109,5 @@ public class EtcPasswdFileReader
return result; return result;
} }
} }
// ////////////////////////////////////////////////////////////////////////

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2006-2021 Christian Pierre MOMON * Copyright (C) 2006-2010,2013-2014,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,13 +16,14 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix; package fr.devinsy.util.unix;
import java.util.Vector; import java.util.Vector;
/** /**
* The Class Group. * The Class Group.
* *
* @author Christian Pierre MOMON (christian.momon@devinsy.fr)
*/ */
public class Group public class Group
{ {
@ -88,9 +89,7 @@ public class Group
} }
/** /**
* Gets the members.
* *
* @return the members
*/ */
public Vector<String> getMembers() public Vector<String> getMembers()
{ {
@ -103,9 +102,7 @@ public class Group
} }
/** /**
* Gets the name.
* *
* @return the name
*/ */
public String getName() public String getName()
{ {
@ -118,9 +115,7 @@ public class Group
} }
/** /**
* Gets the password.
* *
* @return the password
*/ */
public String getPassword() public String getPassword()
{ {
@ -133,9 +128,7 @@ public class Group
} }
/** /**
* Gid.
* *
* @return the int
*/ */
public int gid() public int gid()
{ {
@ -148,9 +141,7 @@ public class Group
} }
/** /**
* Members.
* *
* @return the vector
*/ */
public Vector<String> members() public Vector<String> members()
{ {
@ -163,9 +154,7 @@ public class Group
} }
/** /**
* Name.
* *
* @return the string
*/ */
public String name() public String name()
{ {
@ -178,9 +167,7 @@ public class Group
} }
/** /**
* Passwd.
* *
* @return the string
*/ */
public String passwd() public String passwd()
{ {
@ -193,10 +180,7 @@ public class Group
} }
/** /**
* Sets the gid.
* *
* @param gid
* the new gid
*/ */
public void setGid(final int gid) public void setGid(final int gid)
{ {
@ -204,10 +188,7 @@ public class Group
} }
/** /**
* Sets the name.
* *
* @param name
* the new name
*/ */
public void setName(final String name) public void setName(final String name)
{ {
@ -215,10 +196,7 @@ public class Group
} }
/** /**
* Sets the passwd.
* *
* @param password
* the new passwd
*/ */
public void setPasswd(final String password) public void setPasswd(final String password)
{ {
@ -226,10 +204,7 @@ public class Group
} }
/** /**
* Sets the password.
* *
* @param password
* the new password
*/ */
public void setPassword(final String password) public void setPassword(final String password)
{ {
@ -250,3 +225,5 @@ public class Group
return result; return result;
} }
} }
// ////////////////////////////////////////////////////////////////////////

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2006-2021 Christian Pierre MOMON * Copyright (C) 2006-2010,2013-2014,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix; package fr.devinsy.util.unix;
import java.util.Iterator; import java.util.Iterator;
import java.util.Vector; import java.util.Vector;
@ -24,9 +24,11 @@ import java.util.Vector;
/** /**
* The Class Groups. * The Class Groups.
* *
* @author Christian Pierre MOMON (christian.momon@devinsy.fr)
*/ */
public class Groups extends Vector<Group> public class Groups extends Vector<Group>
{ {
private static final long serialVersionUID = 5802487312198869603L; private static final long serialVersionUID = 5802487312198869603L;
// static private final Logger logger = // static private final Logger logger =
@ -89,11 +91,7 @@ public class Groups extends Vector<Group>
} }
/** /**
* Gets the by gid.
* *
* @param gid
* the gid
* @return the by gid
*/ */
public Group getByGid(final int gid) public Group getByGid(final int gid)
{ {
@ -252,3 +250,5 @@ public class Groups extends Vector<Group>
return result; return result;
} }
} }
// ////////////////////////////////////////////////////////////////////////

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2006-2021 Christian Pierre MOMON * Copyright (C) 2006-2010,2013-2015,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix; package fr.devinsy.util.unix;
import java.io.File; import java.io.File;
import java.util.Vector; import java.util.Vector;
@ -26,15 +26,16 @@ import org.apache.commons.lang3.SystemUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import fr.devinsy.cmdexec.CmdExecException; import fr.devinsy.util.cmdexec.CmdExecException;
import fr.devinsy.cmdexec.CmdExecUtils; import fr.devinsy.util.cmdexec.CmdExecUtils;
import fr.devinsy.strings.StringsUtils; import fr.devinsy.util.strings.StringListUtils;
import fr.devinsy.unix.acl.Acl; import fr.devinsy.util.unix.acl.Acl;
import fr.devinsy.unix.acl.AclManager; import fr.devinsy.util.unix.acl.AclManager;
/** /**
* The Class Unix. * The Class Unix.
* *
* @author Christian Pierre MOMON (christian.momon@devinsy.fr)
*/ */
public class Unix public class Unix
{ {
@ -50,8 +51,8 @@ public class Unix
* the text * the text
* @param path * @param path
* the path * the path
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void appendToFile(final String text, final String path) throws UnixException public static void appendToFile(final String text, final String path) throws UnixException
{ {
@ -98,15 +99,6 @@ public class Unix
return result; return result;
} }
/**
* Bash.
*
* @param command
* the command
* @return the string
* @throws CmdExecException
* the cmd exec exception
*/
public static String bash(final String... command) throws CmdExecException public static String bash(final String... command) throws CmdExecException
{ {
String result; String result;
@ -131,8 +123,8 @@ public class Unix
* the changes * the changes
* @param path * @param path
* the path * the path
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void chmod(final String changes, final String path) throws UnixException public static void chmod(final String changes, final String path) throws UnixException
{ {
@ -165,8 +157,8 @@ public class Unix
* the id * the id
* @param filePathName * @param filePathName
* the file path name * the file path name
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void clearAcl(final String id, final String filePathName) throws UnixException public static void clearAcl(final String id, final String filePathName) throws UnixException
{ {
@ -180,8 +172,8 @@ public class Unix
* the group * the group
* @param filePathName * @param filePathName
* the file path name * the file path name
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void clearAclGroup(final String group, final String filePathName) throws UnixException public static void clearAclGroup(final String group, final String filePathName) throws UnixException
{ {
@ -195,8 +187,8 @@ public class Unix
* the login * the login
* @param filePathName * @param filePathName
* the file path name * the file path name
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void clearAclUser(final String login, final String filePathName) throws UnixException public static void clearAclUser(final String login, final String filePathName) throws UnixException
{ {
@ -208,8 +200,8 @@ public class Unix
* *
* @param login * @param login
* the login * the login
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void createUserAccount(final String login) throws UnixException public static void createUserAccount(final String login) throws UnixException
{ {
@ -230,8 +222,8 @@ public class Unix
* the login * the login
* @param name * @param name
* the name * the name
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void createUserAccount(final String login, final String name) throws UnixException public static void createUserAccount(final String login, final String name) throws UnixException
{ {
@ -258,8 +250,8 @@ public class Unix
* the name * the name
* @param home * @param home
* the home * the home
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void createUserAccount(final String login, final String name, final String home) throws UnixException public static void createUserAccount(final String login, final String name, final String home) throws UnixException
{ {
@ -303,8 +295,8 @@ public class Unix
* the home * the home
* @param password * @param password
* the password * the password
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void createUserAccount(final String login, final String name, final String home, final String password) throws UnixException public static void createUserAccount(final String login, final String name, final String home, final String password) throws UnixException
{ {
@ -328,8 +320,8 @@ public class Unix
* *
* @param group * @param group
* the group * the group
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void deleteGroup(final String group) throws UnixException public static void deleteGroup(final String group) throws UnixException
{ {
@ -354,12 +346,7 @@ public class Unix
} }
/** /**
* Delete user account.
* *
* @param login
* the login
* @throws UnixException
* the unix exception
*/ */
public static void deleteUserAccount(final String login) throws UnixException public static void deleteUserAccount(final String login) throws UnixException
{ {
@ -415,8 +402,8 @@ public class Unix
* @param filePathName * @param filePathName
* the file path name * the file path name
* @return the acl data * @return the acl data
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static String getAclData(final String filePathName) throws UnixException public static String getAclData(final String filePathName) throws UnixException
{ {
@ -434,8 +421,8 @@ public class Unix
* @param filePathName * @param filePathName
* the file path name * the file path name
* @return the acl users * @return the acl users
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static String[] getAclUsers(final String filePathName) throws UnixException public static String[] getAclUsers(final String filePathName) throws UnixException
{ {
@ -490,8 +477,8 @@ public class Unix
* the source path * the source path
* @param targetPath * @param targetPath
* the target path * the target path
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void link(final String sourcePath, final String targetPath) throws UnixException public static void link(final String sourcePath, final String targetPath) throws UnixException
{ {
@ -537,8 +524,8 @@ public class Unix
* the target login * the target login
* @param sourceHomeDirectory * @param sourceHomeDirectory
* the source home directory * the source home directory
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void modifyLogin(final String sourceLogin, final String targetLogin, final String sourceHomeDirectory) throws UnixException public static void modifyLogin(final String sourceLogin, final String targetLogin, final String sourceHomeDirectory) throws UnixException
{ {
@ -614,8 +601,8 @@ public class Unix
* the changes * the changes
* @param path * @param path
* the path * the path
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void recursiveChmod(final String changes, final String path) throws UnixException public static void recursiveChmod(final String changes, final String path) throws UnixException
{ {
@ -741,19 +728,19 @@ public class Unix
* *
* @param args * @param args
* the new facl * the new facl
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static void setfacl(final String... args) throws UnixException public static void setfacl(final String... args) throws UnixException
{ {
try try
{ {
String[] command = ArrayUtils.insert(0, args, "setfacl"); String[] command = ArrayUtils.add(args, 0, "setfacl");
sudo(command); sudo(command);
} }
catch (CmdExecException exception) catch (CmdExecException exception)
{ {
throw new UnixException("Error running setfacl command for " + StringsUtils.toStringWithBrackets(args) + ":" + exception.getMessage() + ".", exception); throw new UnixException("Error running setfacl command for " + StringListUtils.toStringWithBrackets(args) + ":" + exception.getMessage() + ".", exception);
} }
} }
@ -801,7 +788,6 @@ public class Unix
* @param newRealName * @param newRealName
* the new real name * the new real name
* @throws UnixException * @throws UnixException
* the unix exception
*/ */
public static void setRealName(final String login, final String newRealName) throws UnixException public static void setRealName(final String login, final String newRealName) throws UnixException
{ {
@ -868,7 +854,7 @@ public class Unix
if (SystemUtils.IS_OS_UNIX) if (SystemUtils.IS_OS_UNIX)
{ {
String[] newCommand = ArrayUtils.insert(0, command, SUDO); String[] newCommand = ArrayUtils.add(command, 0, SUDO);
result = CmdExecUtils.run(newCommand); result = CmdExecUtils.run(newCommand);
} }
else else
@ -959,3 +945,5 @@ public class Unix
} }
} }
} }
// ////////////////////////////////////////////////////////////////////////

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2016-2018 Christian Pierre MOMON * Copyright (C) 2016-2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix; package fr.devinsy.util.unix;
/** /**
* The Class UnixException. * The Class UnixException.

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2006-2021 Christian Pierre MOMON * Copyright (C) 2006-2010,2013-2014,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,11 +16,12 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix; package fr.devinsy.util.unix;
/** /**
* The Class User. * The Class User.
* *
* @author Christian Pierre MOMON (christian.momon@devinsy.fr)
*/ */
public class User public class User
{ {
@ -408,3 +409,5 @@ public class User
return result; return result;
} }
} }
// ////////////////////////////////////////////////////////////////////////

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2006-2021 Christian Pierre MOMON * Copyright (C) 2006-2010,2013-2014,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix; package fr.devinsy.util.unix;
import java.util.Iterator; import java.util.Iterator;
import java.util.Vector; import java.util.Vector;
@ -24,6 +24,7 @@ import java.util.Vector;
/** /**
* The Class Users. * The Class Users.
* *
* @author Christian Pierre MOMON (christian.momon@devinsy.fr)
*/ */
public class Users extends Vector<User> public class Users extends Vector<User>
{ {
@ -40,12 +41,8 @@ public class Users extends Vector<User>
super(); super();
} }
/** /* (non-Javadoc)
* Adds the all. * @see java.util.Vector#addAll(java.util.Collection)
*
* @param source
* the source
* @return true, if successful
*/ */
public boolean addAll(final Users source) public boolean addAll(final Users source)
{ {
@ -215,3 +212,5 @@ public class Users extends Vector<User>
return result; return result;
} }
} }
// ////////////////////////////////////////////////////////////////////////

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2010, 2013-2014,2017-2018 Christian Pierre MOMON * Copyright (C) 2010, 2013-2014,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix.acl; package fr.devinsy.util.unix.acl;
/** /**
* The Class Acl. * The Class Acl.

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2010, 2013-2014,2017-2018 Christian Pierre MOMON * Copyright (C) 2010, 2013-2014,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix.acl; package fr.devinsy.util.unix.acl;
import java.util.Iterator; import java.util.Iterator;
import java.util.Vector; import java.util.Vector;

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2010,2013-2014,2017-2018 Christian Pierre MOMON * Copyright (C) 2010,2013-2014,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix.acl; package fr.devinsy.util.unix.acl;
/** /**
* The Class AclEntry. * The Class AclEntry.

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2010-2021 Christian Pierre MOMON * Copyright (C) 2010,2013-2015,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix.acl; package fr.devinsy.util.unix.acl;
import java.io.File; import java.io.File;
import java.util.regex.Matcher; import java.util.regex.Matcher;
@ -26,10 +26,10 @@ import org.apache.commons.lang3.ArrayUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import fr.devinsy.cmdexec.CmdExecException; import fr.devinsy.util.cmdexec.CmdExecException;
import fr.devinsy.strings.StringsUtils; import fr.devinsy.util.strings.StringListUtils;
import fr.devinsy.unix.Unix; import fr.devinsy.util.unix.Unix;
import fr.devinsy.unix.UnixException; import fr.devinsy.util.unix.UnixException;
/** /**
* The Class AclManager. * The Class AclManager.
@ -118,7 +118,6 @@ public class AclManager
* the file path name * the file path name
* @return the acl * @return the acl
* @throws UnixException * @throws UnixException
* the unix exception
*/ */
public static Acl getAcl(final String filePathName) throws UnixException public static Acl getAcl(final String filePathName) throws UnixException
{ {
@ -220,8 +219,6 @@ public class AclManager
* @param filePathName * @param filePathName
* the file path name * the file path name
* @return the acl data * @return the acl data
* @throws UnixException
* the unix exception
*/ */
public static String getAclData(final String filePathName) throws UnixException public static String getAclData(final String filePathName) throws UnixException
{ {
@ -302,7 +299,8 @@ public class AclManager
* the depth * the depth
* @return true, if is used * @return true, if is used
* @throws UnixException * @throws UnixException
* the unix exception * @throws Exception
* the exception
*/ */
public static boolean isUsed(final AclEntry.Type type, final String id, final String filePathName, final int depth) throws UnixException public static boolean isUsed(final AclEntry.Type type, final String id, final String filePathName, final int depth) throws UnixException
{ {
@ -356,7 +354,6 @@ public class AclManager
* the depth * the depth
* @return true, if is used * @return true, if is used
* @throws UnixException * @throws UnixException
* the unix exception
*/ */
public static boolean isUsed(final AclEntry.Type type, final String id, final String filePath, final String[] filePathNames, final int depth) throws UnixException public static boolean isUsed(final AclEntry.Type type, final String id, final String filePath, final String[] filePathNames, final int depth) throws UnixException
{ {
@ -422,8 +419,8 @@ public class AclManager
* @param depth * @param depth
* the depth * the depth
* @return true, if is used * @return true, if is used
* @throws UnixException * @throws Exception
* the unix exception * the exception
*/ */
public static boolean isUsed(final String id, final String filePathName, final int depth) throws UnixException public static boolean isUsed(final String id, final String filePathName, final int depth) throws UnixException
{ {
@ -473,7 +470,6 @@ public class AclManager
* the depth * the depth
* @return true, if is used * @return true, if is used
* @throws UnixException * @throws UnixException
* the unix exception
*/ */
public static boolean isUsed(final String id, final String[] filePathNames, final int depth) throws UnixException public static boolean isUsed(final String id, final String[] filePathNames, final int depth) throws UnixException
{ {
@ -520,12 +516,14 @@ public class AclManager
{ {
try try
{ {
String[] newArgs = ArrayUtils.insert(0, args, "setfacl"); String[] newArgs = ArrayUtils.add(args, 0, "setfacl");
Unix.sudo(newArgs); Unix.sudo(newArgs);
} }
catch (CmdExecException exception) catch (CmdExecException exception)
{ {
throw new UnixException("Error running setfacl command for " + StringsUtils.toStringWithBrackets(args) + ":" + exception.getMessage() + "."); throw new UnixException("Error running setfacl command for " + StringListUtils.toStringWithBrackets(args) + ":" + exception.getMessage() + ".");
} }
} }
} }
// ////////////////////////////////////////////////////////////////////////

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2017-2018 Christian Pierre MOMON * Copyright (C) 2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,9 +16,9 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix.demo; package fr.devinsy.util.unix.demo;
import fr.devinsy.strings.StringList; import fr.devinsy.util.strings.StringList;
/** /**
* The Class UnixDemo. * The Class UnixDemo.

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2017-2021 Christian Pierre MOMON * Copyright (C) 2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,11 +16,10 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix.linux; package fr.devinsy.util.unix.linux;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.util.regex.Matcher; import java.util.regex.Matcher;
import java.util.regex.Pattern; import java.util.regex.Pattern;
@ -30,12 +29,13 @@ import org.apache.commons.lang3.time.DurationFormatUtils;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import fr.devinsy.unix.util.Property; import fr.devinsy.util.Property;
import fr.devinsy.unix.util.PropertyList; import fr.devinsy.util.PropertyList;
/** /**
* The Class Linux. * The Class Linux.
* *
* @author Christian Pierre MOMON (christian.momon@devinsy.fr)
*/ */
public class Linux public class Linux
{ {
@ -207,7 +207,6 @@ public class Linux
* *
* @return the string * @return the string
* @throws IOException * @throws IOException
* Signals that an I/O exception has occurred.
*/ */
public static String readProcCpuinfo0() throws IOException public static String readProcCpuinfo0() throws IOException
{ {
@ -237,7 +236,7 @@ public class Linux
{ {
String result; String result;
result = FileUtils.readFileToString(new File("/proc/cpuinfo"), StandardCharsets.UTF_8); result = FileUtils.readFileToString(new File("/proc/cpuinfo"));
// //
return result; return result;
@ -254,7 +253,7 @@ public class Linux
{ {
String result; String result;
result = FileUtils.readFileToString(new File("/proc/meminfo"), StandardCharsets.UTF_8); result = FileUtils.readFileToString(new File("/proc/meminfo"));
// //
return result; return result;
@ -265,13 +264,12 @@ public class Linux
* *
* @return the string * @return the string
* @throws IOException * @throws IOException
* Signals that an I/O exception has occurred.
*/ */
public static String readProcUptimeFile() throws IOException public static String readProcUptimeFile() throws IOException
{ {
String result; String result;
result = FileUtils.readFileToString(new File("/proc/uptime"), StandardCharsets.UTF_8); result = FileUtils.readFileToString(new File("/proc/uptime"));
// //
return result; return result;
@ -288,7 +286,7 @@ public class Linux
{ {
String result; String result;
result = FileUtils.readFileToString(new File("/proc/version"), StandardCharsets.UTF_8); result = FileUtils.readFileToString(new File("/proc/version"));
// //
return result; return result;
@ -311,16 +309,16 @@ public class Linux
if (debianFile.exists()) if (debianFile.exists())
{ {
result = "Debian " + FileUtils.readFileToString(debianFile, StandardCharsets.UTF_8); result = "Debian " + FileUtils.readFileToString(debianFile);
} }
else if (redhatFile.exists()) else if (redhatFile.exists())
{ {
result = FileUtils.readFileToString(redhatFile, StandardCharsets.UTF_8); result = FileUtils.readFileToString(redhatFile);
} }
else if (suseFile.exists()) else if (suseFile.exists())
{ {
// TODO // TODO
result = "SUSE " + FileUtils.readFileToString(debianFile, StandardCharsets.UTF_8); result = "SUSE " + FileUtils.readFileToString(debianFile);
} }
else else
{ {
@ -338,3 +336,5 @@ public class Linux
return result; return result;
} }
} }
// ////////////////////////////////////////////////////////////////////////

View file

@ -23,8 +23,6 @@ import java.io.File;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Test; import org.junit.Test;
import fr.devinsy.unix.util.ChangeableFile;
/** /**
* The Class ChangeableFileTest. * The Class ChangeableFileTest.
*/ */

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2010,2013-2015,2017-2018 Christian Pierre MOMON * Copyright (C) 2010,2013-2015,2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,7 +16,7 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix; package fr.devinsy.util.unix;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Test; import org.junit.Test;

View file

@ -1,5 +1,5 @@
/* /*
* Copyright (C) 2017-2018 Christian Pierre MOMON * Copyright (C) 2017 Christian Pierre MOMON
* *
* This file is part of Devinsy-unix. * This file is part of Devinsy-unix.
* *
@ -16,13 +16,13 @@
* You should have received a copy of the GNU Lesser General Public License * You should have received a copy of the GNU Lesser General Public License
* along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/> * along with Devinsy-unix. If not, see <http://www.gnu.org/licenses/>
*/ */
package fr.devinsy.unix; package fr.devinsy.util.unix;
import java.io.IOException; import java.io.IOException;
import org.junit.Test; import org.junit.Test;
import fr.devinsy.unix.linux.Linux; import fr.devinsy.util.unix.linux.Linux;
/** /**
* The Class LinuxTest. * The Class LinuxTest.