Skip to Content.
Sympa Menu

ndt-dev - [ndt] r359 committed - SamKnows Branch

Subject: NDT-DEV email list created

List archive

[ndt] r359 committed - SamKnows Branch


Chronological Thread 
  • From:
  • To:
  • Subject: [ndt] r359 committed - SamKnows Branch
  • Date: Tue, 01 Jun 2010 16:47:17 +0000

Revision: 359
Author: useofweapons
Date: Tue Jun 1 09:44:58 2010
Log: SamKnows Branch
http://code.google.com/p/ndt/source/detail?r=359

Added:
/branches/SamKnows
/branches/SamKnows/SpeedTest.iml
/branches/SamKnows/SpeedTest.ipr
/branches/SamKnows/SpeedTest.iws
/branches/SamKnows/out
/branches/SamKnows/out/Tcpbw100.jar
/branches/SamKnows/out/index.htm
/branches/SamKnows/sign
/branches/SamKnows/sign/ExportKey.bat
/branches/SamKnows/sign/GenerateKey.bat
/branches/SamKnows/sign/Sign.bat
/branches/SamKnows/sign/tstcert.crt
/branches/SamKnows/src
/branches/SamKnows/src/META-INF
/branches/SamKnows/src/META-INF/arrow.png
/branches/SamKnows/src/META-INF/background.jpg
/branches/SamKnows/src/META-INF/button1.png
/branches/SamKnows/src/META-INF/button2.png
/branches/SamKnows/src/META-INF/interface.xml
/branches/SamKnows/src/META-INF/speedbackground.png
/branches/SamKnows/src/MainForm.java
/branches/SamKnows/src/Tcpbw100.java
/branches/SamKnows/src/Tcpbw100.patch
/branches/SamKnows/src/Tcpbw100_msgs_ca_ES.properties
/branches/SamKnows/src/Tcpbw100_msgs_en_US.properties
/branches/SamKnows/src/Tcpbw100_msgs_fr_FR.properties
/branches/SamKnows/src/Tcpbw100_msgs_nb_NO.properties
/branches/SamKnows/src/Tcpbw100_msgs_nl_NL.properties
/branches/SamKnows/src/Tcpbw100_msgs_pt_BR.properties
/branches/SamKnows/src/Tcpbw100_msgs_ru_RU.properties
/branches/SamKnows/src/main.java
/branches/SamKnows/src/skin
/branches/SamKnows/src/skin/Arrow.java
/branches/SamKnows/src/skin/Button.java
/branches/SamKnows/src/skin/Image.java
/branches/SamKnows/src/skin/Interface.java
/branches/SamKnows/src/skin/Label.java
/branches/SamKnows/src/skin/TextPane.java
/branches/SamKnows/src/skin/control
/branches/SamKnows/src/skin/control/SkinArrow.java
/branches/SamKnows/src/skin/control/SkinButton.java
/branches/SamKnows/src/skin/control/SkinLabel.java
/branches/SamKnows/src/skin/control/SkinPanel.java

=======================================
--- /dev/null
+++ /branches/SamKnows/SpeedTest.iml Tue Jun 1 09:44:58 2010
@@ -0,0 +1,21 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<module relativePaths="true" type="JAVA_MODULE" version="4">
+ <component name="NewModuleRootManager" inherit-compiler-output="true">
+ <exclude-output />
+ <content url="file://$MODULE_DIR$">
+ <sourceFolder url="file://$MODULE_DIR$/src" isTestSource="false" />
+ </content>
+ <orderEntry type="inheritedJdk" />
+ <orderEntry type="sourceFolder" forTests="false" />
+ <orderEntry type="module-library">
+ <library>
+ <CLASSES>
+ <root url="jar://$APPLICATION_HOME_DIR$/lib/javaee.jar!/" />
+ </CLASSES>
+ <JAVADOC />
+ <SOURCES />
+ </library>
+ </orderEntry>
+ </component>
+</module>
+
=======================================
--- /dev/null
+++ /branches/SamKnows/SpeedTest.ipr Tue Jun 1 09:44:58 2010
@@ -0,0 +1,218 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project version="4">
+ <component name="AntConfiguration">
+ <defaultAnt bundledAnt="true" />
+ </component>
+ <component name="ArtifactManager">
+ <artifact name="SpeedTest:jar">
+ <output-path>$PROJECT_DIR$/out</output-path>
+ <root id="root">
+ <element id="archive" name="Tcpbw100.jar">
+ <element id="module-output" name="SpeedTest" />
+ </element>
+ </root>
+ </artifact>
+ </component>
+ <component name="CompilerConfiguration">
+ <option name="DEFAULT_COMPILER" value="Javac" />
+ <resourceExtensions>
+ <entry name=".+\.(properties|xml|html|dtd|tld)" />
+ <entry name=".+\.(gif|png|jpeg|jpg)" />
+ </resourceExtensions>
+ <wildcardResourcePatterns>
+ <entry name="?*.properties" />
+ <entry name="?*.xml" />
+ <entry name="?*.gif" />
+ <entry name="?*.png" />
+ <entry name="?*.jpeg" />
+ <entry name="?*.jpg" />
+ <entry name="?*.html" />
+ <entry name="?*.dtd" />
+ <entry name="?*.tld" />
+ <entry name="?*.ftl" />
+ </wildcardResourcePatterns>
+ <annotationProcessing enabled="false" useClasspath="true" />
+ </component>
+ <component name="CopyrightManager" default="">
+ <module2copyright />
+ </component>
+ <component name="DependencyValidationManager">
+ <option name="SKIP_IMPORT_STATEMENTS" value="false" />
+ </component>
+ <component name="Encoding" useUTFGuessing="true" native2AsciiForPropertiesFiles="false" />
+ <component name="IdProvider" IDEtalkID="B7343A9B6210F4C7D4AED807230D4BA8" />
+ <component name="JavadocGenerationManager">
+ <option name="OUTPUT_DIRECTORY" />
+ <option name="OPTION_SCOPE" value="protected" />
+ <option name="OPTION_HIERARCHY" value="true" />
+ <option name="OPTION_NAVIGATOR" value="true" />
+ <option name="OPTION_INDEX" value="true" />
+ <option name="OPTION_SEPARATE_INDEX" value="true" />
+ <option name="OPTION_DOCUMENT_TAG_USE" value="false" />
+ <option name="OPTION_DOCUMENT_TAG_AUTHOR" value="false" />
+ <option name="OPTION_DOCUMENT_TAG_VERSION" value="false" />
+ <option name="OPTION_DOCUMENT_TAG_DEPRECATED" value="true" />
+ <option name="OPTION_DEPRECATED_LIST" value="true" />
+ <option name="OTHER_OPTIONS" value="" />
+ <option name="HEAP_SIZE" />
+ <option name="LOCALE" />
+ <option name="OPEN_IN_BROWSER" value="true" />
+ </component>
+ <component name="Palette2">
+ <group name="Swing">
+ <item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
+ <default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
+ </item>
+ <item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.png" removable="false" auto-create-binding="false" can-attach-label="false">
+ <default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
+ </item>
+ <item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.png" removable="false" auto-create-binding="false" can-attach-label="false">
+ <default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
+ </item>
+ <item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.png" removable="false" auto-create-binding="false" can-attach-label="true">
+ <default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
+ </item>
+ <item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.png" removable="false" auto-create-binding="true" can-attach-label="false">
+ <default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
+ <initial-values>
+ <property name="text" value="Button" />
+ </initial-values>
+ </item>
+ <item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.png" removable="false" auto-create-binding="true" can-attach-label="false">
+ <default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
+ <initial-values>
+ <property name="text" value="RadioButton" />
+ </initial-values>
+ </item>
+ <item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.png" removable="false" auto-create-binding="true" can-attach-label="false">
+ <default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
+ <initial-values>
+ <property name="text" value="CheckBox" />
+ </initial-values>
+ </item>
+ <item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.png" removable="false" auto-create-binding="false" can-attach-label="false">
+ <default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
+ <initial-values>
+ <property name="text" value="Label" />
+ </initial-values>
+ </item>
+ <item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.png" removable="false" auto-create-binding="true" can-attach-label="true">
+ <default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
+ <preferred-size width="150" height="-1" />
+ </default-constraints>
+ </item>
+ <item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.png" removable="false" auto-create-binding="true" can-attach-label="true">
+ <default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
+ <preferred-size width="150" height="-1" />
+ </default-constraints>
+ </item>
+ <item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.png" removable="false" auto-create-binding="true" can-attach-label="true">
+ <default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
+ <preferred-size width="150" height="-1" />
+ </default-constraints>
+ </item>
+ <item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.png" removable="false" auto-create-binding="true" can-attach-label="true">
+ <default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
+ <preferred-size width="150" height="50" />
+ </default-constraints>
+ </item>
+ <item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
+ <default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
+ <preferred-size width="150" height="50" />
+ </default-constraints>
+ </item>
+ <item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.png" removable="false" auto-create-binding="true" can-attach-label="true">
+ <default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
+ <preferred-size width="150" height="50" />
+ </default-constraints>
+ </item>
+ <item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.png" removable="false" auto-create-binding="true" can-attach-label="true">
+ <default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
+ </item>
+ <item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.png" removable="false" auto-create-binding="true" can-attach-label="false">
+ <default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
+ <preferred-size width="150" height="50" />
+ </default-constraints>
+ </item>
+ <item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.png" removable="false" auto-create-binding="true" can-attach-label="false">
+ <default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
+ <preferred-size width="150" height="50" />
+ </default-constraints>
+ </item>
+ <item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.png" removable="false" auto-create-binding="true" can-attach-label="false">
+ <default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
+ <preferred-size width="150" height="50" />
+ </default-constraints>
+ </item>
+ <item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.png" removable="false" auto-create-binding="true" can-attach-label="false">
+ <default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
+ <preferred-size width="200" height="200" />
+ </default-constraints>
+ </item>
+ <item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.png" removable="false" auto-create-binding="false" can-attach-label="false">
+ <default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
+ <preferred-size width="200" height="200" />
+ </default-constraints>
+ </item>
+ <item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.png" removable="false" auto-create-binding="true" can-attach-label="true">
+ <default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
+ </item>
+ <item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.png" removable="false" auto-create-binding="true" can-attach-label="false">
+ <default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
+ </item>
+ <item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.png" removable="false" auto-create-binding="false" can-attach-label="false">
+ <default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
+ </item>
+ <item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
+ <default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
+ </item>
+ <item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.png" removable="false" auto-create-binding="false" can-attach-label="false">
+ <default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
+ <preferred-size width="-1" height="20" />
+ </default-constraints>
+ </item>
+ <item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.png" removable="false" auto-create-binding="false" can-attach-label="false">
+ <default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
+ </item>
+ <item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.png" removable="false" auto-create-binding="true" can-attach-label="false">
+ <default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
+ </item>
+ </group>
+ </component>
+ <component name="ProjectDetails">
+ <option name="projectName" value="SpeedTest" />
+ </component>
+ <component name="ProjectDictionaryState">
+ <dictionary name="prv">
+ <words>
+ <w>rect</w>
+ </words>
+ </dictionary>
+ </component>
+ <component name="ProjectKey">
+ <option name="state" value="project://D:\work\SK-SpeedTest\trunk\SpeedTest.ipr" />
+ </component>
+ <component name="ProjectModuleManager">
+ <modules>
+ <module fileurl="file://$PROJECT_DIR$/SpeedTest.iml" filepath="$PROJECT_DIR$/SpeedTest.iml" />
+ </modules>
+ </component>
+ <component name="ProjectRootManager" version="2" languageLevel="JDK_1_5" assert-keyword="true" jdk-15="true" project-jdk-name="1.6" project-jdk-type="JavaSDK">
+ <output url="file://$PROJECT_DIR$/out" />
+ </component>
+ <component name="ResourceManagerContainer">
+ <option name="myResourceBundles">
+ <value>
+ <list size="0" />
+ </value>
+ </option>
+ </component>
+ <component name="SvnBranchConfigurationManager">
+ <option name="mySupportsUserInfoFilter" value="true" />
+ </component>
+ <component name="VcsDirectoryMappings">
+ <mapping directory="" vcs="" />
+ </component>
+ <component name="WebServicesPlugin" addRequiredLibraries="true" />
+</project>
+
=======================================
--- /dev/null
+++ /branches/SamKnows/SpeedTest.iws Tue Jun 1 09:44:58 2010
@@ -0,0 +1,573 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<project version="4">
+ <component name="ChangeListManager">
+ <list default="true" readonly="true" id="68b39020-7035-4b6f-b398-e37490c56721" name="Default" comment="" />
+ <ignored path=".idea/workspace.xml" />
+ <ignored path="SpeedTest.iws" />
+ <option name="TRACKING_ENABLED" value="true" />
+ <option name="SHOW_DIALOG" value="false" />
+ <option name="HIGHLIGHT_CONFLICTS" value="true" />
+ <option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
+ <option name="LAST_RESOLUTION" value="IGNORE" />
+ </component>
+ <component name="ChangesViewManager" flattened_view="true" show_ignored="false" />
+ <component name="CreatePatchCommitExecutor">
+ <option name="PATCH_PATH" value="" />
+ <option name="REVERSE_PATCH" value="false" />
+ </component>
+ <component name="DaemonCodeAnalyzer">
+ <disable_hints />
+ </component>
+ <component name="DebuggerManager">
+ <breakpoint_any>
+ <breakpoint>
+ <option name="NOTIFY_CAUGHT" value="true" />
+ <option name="NOTIFY_UNCAUGHT" value="true" />
+ <option name="ENABLED" value="false" />
+ <option name="LOG_ENABLED" value="false" />
+ <option name="LOG_EXPRESSION_ENABLED" value="false" />
+ <option name="SUSPEND_POLICY" value="SuspendAll" />
+ <option name="COUNT_FILTER_ENABLED" value="false" />
+ <option name="COUNT_FILTER" value="0" />
+ <option name="CONDITION_ENABLED" value="false" />
+ <option name="CLASS_FILTERS_ENABLED" value="false" />
+ <option name="INSTANCE_FILTERS_ENABLED" value="false" />
+ <option name="CONDITION" value="" />
+ <option name="LOG_MESSAGE" value="" />
+ </breakpoint>
+ <breakpoint>
+ <option name="NOTIFY_CAUGHT" value="true" />
+ <option name="NOTIFY_UNCAUGHT" value="true" />
+ <option name="ENABLED" value="false" />
+ <option name="LOG_ENABLED" value="false" />
+ <option name="LOG_EXPRESSION_ENABLED" value="false" />
+ <option name="SUSPEND_POLICY" value="SuspendAll" />
+ <option name="COUNT_FILTER_ENABLED" value="false" />
+ <option name="COUNT_FILTER" value="0" />
+ <option name="CONDITION_ENABLED" value="false" />
+ <option name="CLASS_FILTERS_ENABLED" value="false" />
+ <option name="INSTANCE_FILTERS_ENABLED" value="false" />
+ <option name="CONDITION" value="" />
+ <option name="LOG_MESSAGE" value="" />
+ </breakpoint>
+ </breakpoint_any>
+ <breakpoint_rules />
+ <ui_properties />
+ </component>
+ <component name="FavoritesManager">
+ <favorites_list name="SpeedTest" />
+ </component>
+ <component name="FileColors" enabled="true" enabledForTabs="true" />
+ <component name="FileEditorManager">
+ <leaf>
+ <file leaf-file-name="Tcpbw100.java" pinned="false" current="true" current-in-tab="true">
+ <entry file="file://$PROJECT_DIR$/src/Tcpbw100.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="1737" column="0" selection-start="55998" selection-end="55998" vertical-scroll-proportion="0.36397985">
+ <folding />
+ </state>
+ </provider>
+ </entry>
+ </file>
+ </leaf>
+ </component>
+ <component name="FindManager">
+ <FindUsagesManager>
+ <setting name="OPEN_NEW_TAB" value="false" />
+ </FindUsagesManager>
+ </component>
+ <component name="IdeDocumentHistory">
+ <option name="changedFiles">
+ <list>
+ <option value="$PROJECT_DIR$/src/skin/control/SkinPanel.java" />
+ <option value="$PROJECT_DIR$/src/skin/control/ConsoleTextPane.java" />
+ <option value="$PROJECT_DIR$/src/skin/control/SkinArrow.java" />
+ <option value="$PROJECT_DIR$/src/skin/control/SkinButton.java" />
+ <option value="$PROJECT_DIR$/src/skin/control/SkinLabel.java" />
+ <option value="$PROJECT_DIR$/src/skin/Image.java" />
+ <option value="$PROJECT_DIR$/src/MainForm.java" />
+ <option value="$PROJECT_DIR$/src/main.java" />
+ <option value="$PROJECT_DIR$/src/skin/Label.java" />
+ <option value="$PROJECT_DIR$/src/skin/TextPane.java" />
+ <option value="$PROJECT_DIR$/src/skin/Button.java" />
+ <option value="$PROJECT_DIR$/src/skin/Arrow.java" />
+ <option value="$PROJECT_DIR$/src/skin/Interface.java" />
+ <option value="$PROJECT_DIR$/src/Tcpbw100_orig.java" />
+ <option value="$PROJECT_DIR$/src/Tcpbw100.java" />
+ <option value="$PROJECT_DIR$/src/Tcpbw100.patch" />
+ </list>
+ </option>
+ </component>
+ <component name="ModuleEditorState">
+ <option name="LAST_EDITED_MODULE_NAME" />
+ <option name="LAST_EDITED_TAB_NAME" />
+ </component>
+ <component name="ProjectInspectionProfilesVisibleTreeState">
+ <entry key="Project Default">
+ <profile-state />
+ </entry>
+ </component>
+ <component name="ProjectLevelVcsManager">
+ <OptionsSetting value="true" id="Add" />
+ <OptionsSetting value="true" id="Remove" />
+ <OptionsSetting value="true" id="Checkout" />
+ <OptionsSetting value="true" id="Update" />
+ <OptionsSetting value="true" id="Status" />
+ <OptionsSetting value="true" id="Edit" />
+ <ConfirmationsSetting value="0" id="Add" />
+ <ConfirmationsSetting value="0" id="Remove" />
+ </component>
+ <component name="ProjectReloadState">
+ <option name="STATE" value="0" />
+ </component>
+ <component name="ProjectView">
+ <navigator currentView="ProjectPane" proportions="" version="1" splitterProportion="0.5">
+ <flattenPackages />
+ <showMembers />
+ <showModules />
+ <showLibraryContents />
+ <hideEmptyPackages />
+ <abbreviatePackageNames />
+ <autoscrollToSource />
+ <autoscrollFromSource />
+ <sortByType />
+ </navigator>
+ <panes>
+ <pane id="ProjectPane">
+ <subPane>
+ <PATH>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="SpeedTest" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
+ </PATH_ELEMENT>
+ </PATH>
+ <PATH>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="SpeedTest" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
+ </PATH_ELEMENT>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="trunk" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
+ </PATH_ELEMENT>
+ </PATH>
+ <PATH>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="SpeedTest" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
+ </PATH_ELEMENT>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="trunk" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
+ </PATH_ELEMENT>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="src" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
+ </PATH_ELEMENT>
+ </PATH>
+ <PATH>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="SpeedTest" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
+ </PATH_ELEMENT>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="trunk" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
+ </PATH_ELEMENT>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="src" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
+ </PATH_ELEMENT>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="skin" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
+ </PATH_ELEMENT>
+ </PATH>
+ <PATH>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="SpeedTest" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.ProjectViewProjectNode" />
+ </PATH_ELEMENT>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="trunk" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
+ </PATH_ELEMENT>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="src" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
+ </PATH_ELEMENT>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="skin" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
+ </PATH_ELEMENT>
+ <PATH_ELEMENT>
+ <option name="myItemId" value="control" />
+ <option name="myItemType" value="com.intellij.ide.projectView.impl.nodes.PsiDirectoryNode" />
+ </PATH_ELEMENT>
+ </PATH>
+ </subPane>
+ </pane>
+ <pane id="Favorites" />
+ <pane id="PackagesPane" />
+ <pane id="Scope" />
+ </panes>
+ </component>
+ <component name="PropertiesComponent">
+ <property name="GoToFile.includeJavaFiles" value="false" />
+ <property name="options.splitter.main.proportions" value="0.3" />
+ <property name="recentsLimit" value="5" />
+ <property name="MemberChooser.sorted" value="false" />
+ <property name="options.lastSelected" value="preferences.sourceCode" />
+ <property name="ChangesBrowser.SHOW_FLATTEN" value="true" />
+ <property name="MemberChooser.copyJavadoc" value="false" />
+ <property name="GoToClass.toSaveIncludeLibraries" value="false" />
+ <property name="MemberChooser.showClasses" value="true" />
+ <property name="GoToClass.includeLibraries" value="false" />
+ <property name="dynamic.classpath" value="false" />
+ <property name="options.splitter.details.proportions" value="0.2" />
+ <property name="options.searchVisible" value="true" />
+ </component>
+ <component name="RunManager" selected="Application.main">
+ <configuration default="false" name="Tcpbw100" type="Application" factoryName="Application" temporary="true">
+ <extension name="snapshooter" />
+ <option name="MAIN_CLASS_NAME" value="Tcpbw100" />
+ <option name="VM_PARAMETERS" />
+ <option name="PROGRAM_PARAMETERS" />
+ <option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
+ <option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
+ <option name="ALTERNATIVE_JRE_PATH" />
+ <option name="ENABLE_SWING_INSPECTOR" value="false" />
+ <option name="ENV_VARIABLES" />
+ <option name="PASS_PARENT_ENVS" value="true" />
+ <module name="SpeedTest" />
+ <envs />
+ <RunnerSettings RunnerId="Run" />
+ <ConfigurationWrapper RunnerId="Run" />
+ <method />
+ </configuration>
+ <configuration default="false" name="main" type="Application" factoryName="Application" temporary="true">
+ <extension name="snapshooter" />
+ <option name="MAIN_CLASS_NAME" value="main" />
+ <option name="VM_PARAMETERS" />
+ <option name="PROGRAM_PARAMETERS" />
+ <option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
+ <option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
+ <option name="ALTERNATIVE_JRE_PATH" />
+ <option name="ENABLE_SWING_INSPECTOR" value="false" />
+ <option name="ENV_VARIABLES" />
+ <option name="PASS_PARENT_ENVS" value="true" />
+ <module name="SpeedTest" />
+ <envs />
+ <RunnerSettings RunnerId="Run" />
+ <ConfigurationWrapper RunnerId="Run" />
+ <method />
+ </configuration>
+ <configuration default="true" type="Remote" factoryName="Remote">
+ <option name="USE_SOCKET_TRANSPORT" value="true" />
+ <option name="SERVER_MODE" value="false" />
+ <option name="SHMEM_ADDRESS" value="javadebug" />
+ <option name="HOST" value="localhost" />
+ <option name="PORT" value="5005" />
+ <method>
+ <option name="AntTarget" enabled="false" />
+ <option name="BuildArtifacts" enabled="false" />
+ <option name="Maven.BeforeRunTask" enabled="false" />
+ </method>
+ </configuration>
+ <configuration default="true" type="TestNG" factoryName="TestNG">
+ <extension name="snapshooter" />
+ <module name="" />
+ <option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
+ <option name="ALTERNATIVE_JRE_PATH" />
+ <option name="SUITE_NAME" />
+ <option name="PACKAGE_NAME" />
+ <option name="MAIN_CLASS_NAME" />
+ <option name="METHOD_NAME" />
+ <option name="GROUP_NAME" />
+ <option name="TEST_OBJECT" value="CLASS" />
+ <option name="VM_PARAMETERS" />
+ <option name="PARAMETERS" />
+ <option name="WORKING_DIRECTORY" />
+ <option name="OUTPUT_DIRECTORY" />
+ <option name="ANNOTATION_TYPE" />
+ <option name="ENV_VARIABLES" />
+ <option name="PASS_PARENT_ENVS" value="true" />
+ <option name="TEST_SEARCH_SCOPE">
+ <value defaultName="moduleWithDependencies" />
+ </option>
+ <option name="USE_DEFAULT_REPORTERS" value="false" />
+ <option name="PROPERTIES_FILE" />
+ <envs />
+ <properties />
+ <listeners />
+ <method>
+ <option name="AntTarget" enabled="false" />
+ <option name="BuildArtifacts" enabled="false" />
+ <option name="Make" enabled="true" />
+ <option name="Maven.BeforeRunTask" enabled="false" />
+ </method>
+ </configuration>
+ <configuration default="true" type="Applet" factoryName="Applet">
+ <module name="" />
+ <option name="MAIN_CLASS_NAME" />
+ <option name="HTML_FILE_NAME" />
+ <option name="HTML_USED" value="false" />
+ <option name="WIDTH" value="400" />
+ <option name="HEIGHT" value="300" />
+ <option name="POLICY_FILE" value="$APPLICATION_HOME_DIR$/bin/appletviewer.policy" />
+ <option name="VM_PARAMETERS" />
+ <option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
+ <option name="ALTERNATIVE_JRE_PATH" />
+ <method>
+ <option name="AntTarget" enabled="false" />
+ <option name="BuildArtifacts" enabled="false" />
+ <option name="Make" enabled="true" />
+ <option name="Maven.BeforeRunTask" enabled="false" />
+ </method>
+ </configuration>
+ <configuration default="true" type="Application" factoryName="Application">
+ <extension name="snapshooter" />
+ <option name="MAIN_CLASS_NAME" />
+ <option name="VM_PARAMETERS" />
+ <option name="PROGRAM_PARAMETERS" />
+ <option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
+ <option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
+ <option name="ALTERNATIVE_JRE_PATH" />
+ <option name="ENABLE_SWING_INSPECTOR" value="false" />
+ <option name="ENV_VARIABLES" />
+ <option name="PASS_PARENT_ENVS" value="true" />
+ <module name="" />
+ <envs />
+ <method>
+ <option name="AntTarget" enabled="false" />
+ <option name="BuildArtifacts" enabled="false" />
+ <option name="Make" enabled="true" />
+ <option name="Maven.BeforeRunTask" enabled="false" />
+ </method>
+ </configuration>
+ <configuration default="true" type="JUnit" factoryName="JUnit">
+ <extension name="snapshooter" />
+ <module name="" />
+ <option name="ALTERNATIVE_JRE_PATH_ENABLED" value="false" />
+ <option name="ALTERNATIVE_JRE_PATH" />
+ <option name="PACKAGE_NAME" />
+ <option name="MAIN_CLASS_NAME" />
+ <option name="METHOD_NAME" />
+ <option name="TEST_OBJECT" value="class" />
+ <option name="VM_PARAMETERS" />
+ <option name="PARAMETERS" />
+ <option name="WORKING_DIRECTORY" value="$PROJECT_DIR$" />
+ <option name="ENV_VARIABLES" />
+ <option name="PASS_PARENT_ENVS" value="true" />
+ <option name="TEST_SEARCH_SCOPE">
+ <value defaultName="moduleWithDependencies" />
+ </option>
+ <envs />
+ <method>
+ <option name="AntTarget" enabled="false" />
+ <option name="BuildArtifacts" enabled="false" />
+ <option name="Make" enabled="true" />
+ <option name="Maven.BeforeRunTask" enabled="false" />
+ </method>
+ </configuration>
+ <list size="2">
+ <item index="0" class="java.lang.String" itemvalue="Application.Tcpbw100" />
+ <item index="1" class="java.lang.String" itemvalue="Application.main" />
+ </list>
+ <configuration name="&lt;template&gt;" type="WebApp" default="true" selected="false">
+ <Host>localhost</Host>
+ <Port>5050</Port>
+ </configuration>
+ </component>
+ <component name="ShelveChangesManager" show_recycled="false" />
+ <component name="SvnConfiguration" maxAnnotateRevisions="500">
+ <option name="USER" value="" />
+ <option name="PASSWORD" value="" />
+ <option name="LAST_MERGED_REVISION" />
+ <option name="UPDATE_RUN_STATUS" value="false" />
+ <option name="MERGE_DRY_RUN" value="false" />
+ <option name="MERGE_DIFF_USE_ANCESTRY" value="true" />
+ <option name="UPDATE_LOCK_ON_DEMAND" value="false" />
+ <option name="IGNORE_SPACES_IN_MERGE" value="false" />
+ <option name="DETECT_NESTED_COPIES" value="false" />
+ <option name="IGNORE_SPACES_IN_ANNOTATE" value="true" />
+ <option name="SHOW_MERGE_SOURCES_IN_ANNOTATE" value="true" />
+ <configuration useDefault="false">C:\Users\vda\AppData\Roaming\Subversion</configuration>
+ <myIsUseDefaultProxy>false</myIsUseDefaultProxy>
+ <supportedVersion>125</supportedVersion>
+ </component>
+ <component name="ToolWindowManager">
+ <frame x="-8" y="-8" width="1296" height="1000" extended-state="6" />
+ <editor active="true" />
+ <layout>
+ <window_info id="Changes" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
+ <window_info id="Palette" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
+ <window_info id="Ant Build" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.2495935" sideWeight="0.66190475" order="1" side_tool="false" content_ui="tabs" />
+ <window_info id="Find" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.3297619" sideWeight="0.5" order="1" side_tool="false" content_ui="tabs" />
+ <window_info id="Debug" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
+ <window_info id="Version Control" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
+ <window_info id="Messages" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.3297619" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
+ <window_info id="TODO" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="6" side_tool="false" content_ui="tabs" />
+ <window_info id="Structure" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="1" side_tool="true" content_ui="tabs" />
+ <window_info id="Maven Projects" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="3" side_tool="false" content_ui="tabs" />
+ <window_info id="Commander" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
+ <window_info id="Project" active="false" anchor="left" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="true" weight="0.2495935" sideWeight="0.66190475" order="0" side_tool="false" content_ui="tabs" />
+ <window_info id="Dependency Viewer" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="7" side_tool="false" content_ui="tabs" />
+ <window_info id="Run" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.3297619" sideWeight="0.5" order="2" side_tool="false" content_ui="tabs" />
+ <window_info id="Cvs" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="4" side_tool="false" content_ui="tabs" />
+ <window_info id="Message" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.33" sideWeight="0.5" order="0" side_tool="false" content_ui="tabs" />
+ <window_info id="Hierarchy" active="false" anchor="right" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.25" sideWeight="0.5" order="2" side_tool="false" content_ui="combo" />
+ <window_info id="Inspection" active="false" anchor="bottom" auto_hide="false" internal_type="DOCKED" type="DOCKED" visible="false" weight="0.4" sideWeight="0.5" order="5" side_tool="false" content_ui="tabs" />
+ </layout>
+ </component>
+ <component name="VcsManagerConfiguration">
+ <option name="OFFER_MOVE_TO_ANOTHER_CHANGELIST_ON_PARTIAL_COMMIT" value="true" />
+ <option name="CHECK_CODE_SMELLS_BEFORE_PROJECT_COMMIT" value="true" />
+ <option name="PERFORM_UPDATE_IN_BACKGROUND" value="true" />
+ <option name="PERFORM_COMMIT_IN_BACKGROUND" value="true" />
+ <option name="PERFORM_EDIT_IN_BACKGROUND" value="true" />
+ <option name="PERFORM_CHECKOUT_IN_BACKGROUND" value="true" />
+ <option name="PERFORM_ADD_REMOVE_IN_BACKGROUND" value="true" />
+ <option name="PERFORM_ROLLBACK_IN_BACKGROUND" value="false" />
+ <option name="CHECK_LOCALLY_CHANGED_CONFLICTS_IN_BACKGROUND" value="true" />
+ <option name="ENABLE_BACKGROUND_PROCESSES" value="false" />
+ <option name="CHANGED_ON_SERVER_INTERVAL" value="60" />
+ <option name="FORCE_NON_EMPTY_COMMENT" value="false" />
+ <option name="LAST_COMMIT_MESSAGE" />
+ <option name="MAKE_NEW_CHANGELIST_ACTIVE" value="true" />
+ <option name="OPTIMIZE_IMPORTS_BEFORE_PROJECT_COMMIT" value="false" />
+ <option name="CHECK_FILES_UP_TO_DATE_BEFORE_COMMIT" value="false" />
+ <option name="REFORMAT_BEFORE_PROJECT_COMMIT" value="false" />
+ <option name="REFORMAT_BEFORE_FILE_COMMIT" value="false" />
+ <option name="FILE_HISTORY_DIALOG_COMMENTS_SPLITTER_PROPORTION" value="0.8" />
+ <option name="FILE_HISTORY_DIALOG_SPLITTER_PROPORTION" value="0.5" />
+ <option name="ACTIVE_VCS_NAME" />
+ <option name="UPDATE_GROUP_BY_PACKAGES" value="false" />
+ <option name="UPDATE_GROUP_BY_CHANGELIST" value="false" />
+ <option name="SHOW_FILE_HISTORY_AS_TREE" value="false" />
+ <option name="FILE_HISTORY_SPLITTER_PROPORTION" value="0.6" />
+ </component>
+ <component name="XDebuggerManager">
+ <breakpoint-manager />
+ </component>
+ <component name="antWorkspaceConfiguration">
+ <option name="IS_AUTOSCROLL_TO_SOURCE" value="false" />
+ <option name="FILTER_TARGETS" value="false" />
+ </component>
+ <component name="editorHistoryManager">
+ <entry file="jar://C:/Program Files/Java/jdk1.6.0_18/src.zip!/java/awt/image/BufferedImage.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="52" column="13" selection-start="1730" selection-end="1730" vertical-scroll-proportion="-0.24621212" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/skin/control/SkinArrow.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="81" column="12" selection-start="2270" selection-end="2270" vertical-scroll-proportion="0.23018868" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/skin/control/SkinButton.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="42" column="81" selection-start="1356" selection-end="1356" vertical-scroll-proportion="0.81650245" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/skin/control/SkinLabel.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="27" column="0" selection-start="821" selection-end="821" vertical-scroll-proportion="0.50246304" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/skin/control/SkinPanel.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="7" column="13" selection-start="102" selection-end="102" vertical-scroll-proportion="-2.0775862" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/skin/TextPane.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="11" column="0" selection-start="194" selection-end="194" vertical-scroll-proportion="0.23581336" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/main.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="22" column="0" selection-start="1352" selection-end="1352" vertical-scroll-proportion="0.0" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/skin/Image.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="5" column="13" selection-start="77" selection-end="77" vertical-scroll-proportion="0.08374384" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/skin/Arrow.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="17" column="0" selection-start="404" selection-end="404" vertical-scroll-proportion="-0.8214286" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/skin/Label.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="13" column="0" selection-start="281" selection-end="281" vertical-scroll-proportion="0.08050314" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/skin/Button.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="19" column="0" selection-start="387" selection-end="387" vertical-scroll-proportion="-0.54433495" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/MainForm.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="24" column="46" selection-start="562" selection-end="562" vertical-scroll-proportion="0.33497536" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/skin/Interface.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="21" column="30" selection-start="636" selection-end="636" vertical-scroll-proportion="0.25123152" />
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/Tcpbw100.java.last">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="315" column="13" selection-start="11271" selection-end="11278" vertical-scroll-proportion="-34.72">
+ <folding />
+ </state>
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/Tcpbw100.patch">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="608" column="0" selection-start="19769" selection-end="19770" vertical-scroll-proportion="0.85012597">
+ <folding />
+ </state>
+ </provider>
+ </entry>
+ <entry file="file://$PROJECT_DIR$/src/Tcpbw100.java">
+ <provider selected="true" editor-type-id="text-editor">
+ <state line="1737" column="0" selection-start="55998" selection-end="55998" vertical-scroll-proportion="0.36397985">
+ <folding />
+ </state>
+ </provider>
+ </entry>
+ </component>
+ <component name="masterDetails">
+ <states>
+ <state key="ArtifactsStructureConfigurable.UI">
+ <UIState>
+ <splitter-proportions>
+ <SplitterProportionsDataImpl />
+ </splitter-proportions>
+ <settings />
+ </UIState>
+ </state>
+ <state key="Copyright.UI">
+ <UIState>
+ <splitter-proportions>
+ <SplitterProportionsDataImpl />
+ </splitter-proportions>
+ </UIState>
+ </state>
+ <state key="ScopeChooserConfigurable.UI">
+ <UIState>
+ <splitter-proportions>
+ <SplitterProportionsDataImpl />
+ </splitter-proportions>
+ <settings />
+ </UIState>
+ </state>
+ </states>
+ </component>
+</project>
+
=======================================
--- /dev/null
+++ /branches/SamKnows/out/Tcpbw100.jar Tue Jun 1 09:44:58 2010
Binary file, no diff available.
=======================================
--- /dev/null
+++ /branches/SamKnows/out/index.htm Tue Jun 1 09:44:58 2010
@@ -0,0 +1,21 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
+<html>
+<head>
+<title>M-Lab3 node NDT server</title>
+<meta http-equiv="Content-Language" content="en">
+<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
+</head>
+<body>
+<center>
+<applet code=Tcpbw100.class ARCHIVE="Tcpbw100.jar"
+ width=800 height=600>
+ <PARAM NAME="testingServer" VALUE="ndt.iupui.lhr01.measurement-lab.org">
+ <PARAM NAME="H" VALUE="gmail.com">
+ <PARAM NAME="U" VALUE="rcarlson501">
+ <PARAM NAME="subject" VALUE="Trouble report from mlab3.lhr01.measurement-lab.org">
+ <PARAM NAME="resultServer" VALUE="http://inmarsoft.com/~vda/test.php";>
+ <PARAM NAME="sessionid" VALUE="">
+</applet>
+</center>
+</body>
+</html>
=======================================
--- /dev/null
+++ /branches/SamKnows/sign/ExportKey.bat Tue Jun 1 09:44:58 2010
@@ -0,0 +1,3 @@
+set JDK_PATH="C:\\Program Files\\Java\\jdk1.6.0_18"
+
+%JDK_PATH%\\bin\\keytool -export -alias tstkey -file tstcert.crt
=======================================
--- /dev/null
+++ /branches/SamKnows/sign/GenerateKey.bat Tue Jun 1 09:44:58 2010
@@ -0,0 +1,3 @@
+set JDK_PATH="C:\\Program Files\\Java\\jdk1.6.0_18"
+
+%JDK_PATH%\\bin\\keytool -genkey -keyalg rsa -alias tstkey
=======================================
--- /dev/null
+++ /branches/SamKnows/sign/Sign.bat Tue Jun 1 09:44:58 2010
@@ -0,0 +1,3 @@
+set JDK_PATH="C:\\Program Files\\Java\\jdk1.6.0_18"
+
+%JDK_PATH%\\bin\\jarsigner ..\\out\\Tcpbw100.jar tstkey
=======================================
--- /dev/null
+++ /branches/SamKnows/sign/tstcert.crt Tue Jun 1 09:44:58 2010
Binary file, no diff available.
=======================================
--- /dev/null
+++ /branches/SamKnows/src/META-INF/arrow.png Tue Jun 1 09:44:58 2010
@@ -0,0 +1,14 @@
+‰PNG
+
+
+IHDRZ ÿzšPsRGB®Î
+égAMA± üa pHYsÃÃÇo¨dtEXtSoftwarePaint.NET v3.5.1Nç8ùÅIDATXGíÖ1
+€0 Ќ
+ÁÑÑÑÑÑ#8:::zoâѼ‰5EŠ±D›*.¦
+@„"ø¾8V†í€e¼ÊÉ
+Õ-ÂLXÆÕ
+°`ßÇ  0ob^ö×½>t,¸dŠ¹çò¯€Òﺂ–‚Bh‹¯z
+ oÁ'’94RdñS‹S†'è÷ ¡ƒ°à ¿
+FäÂ^6D?B÷sL-ŒZ
+ìÐ*!v«ZyG:Ý£¹Èà€©['ÀÖî|
+¦xõ¶úIvHÜDK74àá€e(©ÜIEND®B`‚
=======================================
--- /dev/null
+++ /branches/SamKnows/src/META-INF/background.jpg Tue Jun 1 09:44:58
2010
Binary file, no diff available.
=======================================
--- /dev/null
+++ /branches/SamKnows/src/META-INF/button1.png Tue Jun 1 09:44:58 2010
Binary file, no diff available.
=======================================
--- /dev/null
+++ /branches/SamKnows/src/META-INF/button2.png Tue Jun 1 09:44:58 2010
Binary file, no diff available.
=======================================
--- /dev/null
+++ /branches/SamKnows/src/META-INF/interface.xml Tue Jun 1 09:44:58
2010
@@ -0,0 +1,396 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<java version="1.6.0_14" class="java.beans.XMLDecoder">
+ <object class="skin.Interface">
+ <void property="arrow1">
+ <object class="skin.Arrow">
+ <void property="arrowAnchorX">
+ <int>5</int>
+ </void>
+ <void property="arrowAnchorY">
+ <int>5</int>
+ </void>
+ <void property="arrowImageName">
+ <string>META-INF/arrow.png</string>
+ </void>
+ <void property="arrowX">
+ <int>160</int>
+ </void>
+ <void property="arrowY">
+ <int>140</int>
+ </void>
+ <void property="firstAngle">
+ <int>150</int>
+ </void>
+ <void property="lastAngle">
+ <int>390</int>
+ </void>
+ <void property="scales">
+ <array class="int" length="13">
+ <void index="1">
+ <int>50</int>
+ </void>
+ <void index="2">
+ <int>100</int>
+ </void>
+ <void index="3">
+ <int>300</int>
+ </void>
+ <void index="4">
+ <int>500</int>
+ </void>
+ <void index="5">
+ <int>1000</int>
+ </void>
+ <void index="6">
+ <int>2000</int>
+ </void>
+ <void index="7">
+ <int>4000</int>
+ </void>
+ <void index="8">
+ <int>8000</int>
+ </void>
+ <void index="9">
+ <int>16000</int>
+ </void>
+ <void index="10">
+ <int>30000</int>
+ </void>
+ <void index="11">
+ <int>50000</int>
+ </void>
+ <void index="12">
+ <int>100000</int>
+ </void>
+ </array>
+ </void>
+ <void property="visible">
+ <boolean>true</boolean>
+ </void>
+ </object>
+ </void>
+ <void property="background1Image">
+ <object class="skin.Image">
+ <void property="imageName">
+ <string>META-INF/speedbackground.png</string>
+ </void>
+ <void property="rect">
+ <object class="java.awt.Rectangle">
+ <int>30</int>
+ <int>10</int>
+ <int>260</int>
+ <int>260</int>
+ </object>
+ </void>
+ <void property="visible">
+ <boolean>true</boolean>
+ </void>
+ </object>
+ </void>
+ <void property="startButton">
+ <object class="skin.Button">
+ <void property="imageName">
+ <string>META-INF/button1.png</string>
+ </void>
+ <void property="pressedImageName">
+ <string>META-INF/button2.png</string>
+ </void>
+ <void property="rect">
+ <object class="java.awt.Rectangle">
+ <int>100</int>
+ <int>300</int>
+ <int>120</int>
+ <int>50</int>
+ </object>
+ </void>
+ <void property="text">
+ <string>Start</string>
+ </void>
+ <void property="textColor">
+ <object id="Color0" class="java.awt.Color">
+ <int>255</int>
+ <int>0</int>
+ <int>0</int>
+ <int>255</int>
+ </object>
+ </void>
+ <void property="textFont">
+ <object class="java.awt.Font">
+ <string>Arial</string>
+ <int>2</int>
+ <int>20</int>
+ </object>
+ </void>
+ </object>
+ </void>
+ <void property="stopButton">
+ <object class="skin.Button">
+ <void property="imageName">
+ <string>META-INF/button1.png</string>
+ </void>
+ <void property="pressedImageName">
+ <string>META-INF/button2.png</string>
+ </void>
+ <void property="rect">
+ <object class="java.awt.Rectangle">
+ <int>240</int>
+ <int>300</int>
+ <int>120</int>
+ <int>50</int>
+ </object>
+ </void>
+ <void property="text">
+ <string>Stop</string>
+ </void>
+ <void property="textColor">
+ <object id="Color1" class="java.awt.Color">
+ <int>0</int>
+ <int>255</int>
+ <int>0</int>
+ <int>255</int>
+ </object>
+ </void>
+ <void property="textFont">
+ <object class="java.awt.Font">
+ <string>Arial</string>
+ <int>2</int>
+ <int>20</int>
+ </object>
+ </void>
+ </object>
+ </void>
+ <void property="advancedButton">
+ <object class="skin.Button">
+ <void property="imageName">
+ <string>META-INF/button1.png</string>
+ </void>
+ <void property="pressedImageName">
+ <string>META-INF/button2.png</string>
+ </void>
+ <void property="rect">
+ <object class="java.awt.Rectangle">
+ <int>380</int>
+ <int>300</int>
+ <int>120</int>
+ <int>50</int>
+ </object>
+ </void>
+ <void property="text">
+ <string>Advanced</string>
+ </void>
+ <void property="textColor">
+ <object class="java.awt.Color">
+ <int>0</int>
+ <int>0</int>
+ <int>255</int>
+ <int>255</int>
+ </object>
+ </void>
+ <void property="textFont">
+ <object class="java.awt.Font">
+ <string>Arial</string>
+ <int>2</int>
+ <int>20</int>
+ </object>
+ </void>
+ </object>
+ </void>
+ <void property="lossLabel">
+ <object class="skin.Label">
+ <void property="horizontalAlignment">
+ <int>11</int>
+ </void>
+ <void property="rect">
+ <object class="java.awt.Rectangle">
+ <int>400</int>
+ <int>100</int>
+ <int>100</int>
+ <int>20</int>
+ </object>
+ </void>
+ <void property="textColor">
+ <object id="Color2" class="java.awt.Color">
+ <int>0</int>
+ <int>255</int>
+ <int>255</int>
+ <int>255</int>
+ </object>
+ </void>
+ <void property="textFont">
+ <object class="java.awt.Font">
+ <string>Arial</string>
+ <int>3</int>
+ <int>12</int>
+ </object>
+ </void>
+ <void property="visible">
+ <boolean>true</boolean>
+ </void>
+ </object>
+ </void>
+ <void property="mainBackgroundImage">
+ <object class="skin.Image">
+ <void property="imageName">
+ <string>META-INF/background.jpg</string>
+ </void>
+ <void property="rect">
+ <object class="java.awt.Rectangle">
+ <int>0</int>
+ <int>0</int>
+ <int>600</int>
+ <int>400</int>
+ </object>
+ </void>
+ <void property="visible">
+ <boolean>true</boolean>
+ </void>
+ </object>
+ </void>
+ <void property="rttLabel">
+ <object class="skin.Label">
+ <void property="horizontalAlignment">
+ <int>10</int>
+ </void>
+ <void property="rect">
+ <object class="java.awt.Rectangle">
+ <int>400</int>
+ <int>50</int>
+ <int>100</int>
+ <int>20</int>
+ </object>
+ </void>
+ <void property="textColor">
+ <object idref="Color2"/>
+ </void>
+ <void property="textFont">
+ <object class="java.awt.Font">
+ <string>Arial</string>
+ <int>3</int>
+ <int>12</int>
+ </object>
+ </void>
+ <void property="visible">
+ <boolean>true</boolean>
+ </void>
+ </object>
+ </void>
+ <void property="statusLabel">
+ <object class="skin.Label">
+ <void property="horizontalAlignment">
+ <int>4</int>
+ </void>
+ <void property="rect">
+ <object class="java.awt.Rectangle">
+ <int>200</int>
+ <int>275</int>
+ <int>200</int>
+ <int>20</int>
+ </object>
+ </void>
+ <void property="textColor">
+ <object idref="Color2"/>
+ </void>
+ <void property="textFont">
+ <object class="java.awt.Font">
+ <string>Arial</string>
+ <int>3</int>
+ <int>12</int>
+ </object>
+ </void>
+ <void property="visible">
+ <boolean>true</boolean>
+ </void>
+ </object>
+ </void>
+ <void property="textPane">
+ <object class="skin.TextPane">
+ <void property="h">
+ <int>150</int>
+ </void>
+ <void property="w">
+ <int>560</int>
+ </void>
+ <void property="x">
+ <int>120</int>
+ </void>
+ <void property="y">
+ <int>350</int>
+ </void>
+ </object>
+ </void>
+ <void property="value1Label">
+ <object class="skin.Label">
+ <void property="horizontalAlignment">
+ <int>2</int>
+ </void>
+ <void property="rect">
+ <object class="java.awt.Rectangle">
+ <int>115</int>
+ <int>232</int>
+ <int>87</int>
+ <int>20</int>
+ </object>
+ </void>
+ <void property="textColor">
+ <object idref="Color1"/>
+ </void>
+ <void property="textFont">
+ <object class="java.awt.Font">
+ <string>Arial</string>
+ <int>1</int>
+ <int>12</int>
+ </object>
+ </void>
+ <void property="visible">
+ <boolean>true</boolean>
+ </void>
+ </object>
+ </void>
+ <void property="value2Label">
+ <object class="skin.Label">
+ <void property="rect">
+ <object class="java.awt.Rectangle">
+ <int>395</int>
+ <int>232</int>
+ <int>87</int>
+ <int>20</int>
+ </object>
+ </void>
+ <void property="textColor">
+ <object idref="Color0"/>
+ </void>
+ <void property="textFont">
+ <object class="java.awt.Font">
+ <string>Arial</string>
+ <int>1</int>
+ <int>12</int>
+ </object>
+ </void>
+ <void property="visible">
+ <boolean>true</boolean>
+ </void>
+ </object>
+ </void>
+ <void property="preparingTestString">
+ <string>Preparing speed test</string>
+ </void>
+ <void property="firewallTestString">
+ <string>Simple firewall test</string>
+ </void>
+ <void property="downloadTestString">
+ <string>Download test</string>
+ </void>
+ <void property="uploadTestString">
+ <string>Upload test</string>
+ </void>
+ <void property="completeTestString">
+ <string>Complete</string>
+ </void>
+ <void property="waitString">
+ <string>Please, wait</string>
+ </void>
+ <void property="stopString">
+ <string>Test was stopped</string>
+ </void>
+ </object>
+</java>
=======================================
--- /dev/null
+++ /branches/SamKnows/src/META-INF/speedbackground.png Tue Jun 1 09:44:58 2010
Binary file, no diff available.
=======================================
--- /dev/null
+++ /branches/SamKnows/src/MainForm.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,53 @@
+import skin.Interface;
+import skin.control.SkinButton;
+import skin.control.SkinPanel;
+
+import javax.swing.*;
+import java.awt.*;
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import java.util.Random;
+
+public class MainForm extends JDialog {
+
+ private static Random rn = new Random();
+
+ public static int rand(int lo, int hi) {
+ int n = hi - lo + 1;
+ int i = rn.nextInt() % n;
+ if (i < 0)
+ i = -i;
+ return lo + i;
+ }
+
+ public MainForm() {
+
+ Interface skin = Interface.getInstance();
+
+ final SkinPanel contentPane = new SkinPanel(skin);
+ contentPane.setLayout(null);
+
+ SkinButton btn = contentPane.getStartButton();
+
+ setContentPane(contentPane);
+
+ Insets insets = this.getInsets();
+ setSize(600 + insets.left + insets.right,
+ 400 + insets.top + insets.bottom);
+
+
+ btn.addActionListener(new ActionListener() {
+ public void actionPerformed(ActionEvent e) {
+ contentPane.setValue1(rand(0, 100000));
+ contentPane.setValue2(rand(0, 100000));
+ }
+ });
+
+
+ setLocationRelativeTo(null);
+
+ setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
+
+ }
+
+}
=======================================
--- /dev/null
+++ /branches/SamKnows/src/Tcpbw100.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,3044 @@
+/*
+Copyright 2003 University of Chicago. All rights reserved.
+The Web100 Network Diagnostic Tool (NDT) is distributed subject to
+the following license conditions:
+SOFTWARE LICENSE AGREEMENT
+Software: Web100 Network Diagnostic Tool (NDT)
+
+1. The "Software", below, refers to the Web100 Network Diagnostic Tool (NDT)
+(in either source code, or binary form and accompanying documentation). Each
+licensee is addressed as "you" or "Licensee."
+
+2. The copyright holder shown above hereby grants Licensee a royalty-free
+nonexclusive license, subject to the limitations stated herein and U.S. Government
+license rights.
+
+3. You may modify and make a copy or copies of the Software for use within your
+organization, if you meet the following conditions:
+ a. Copies in source code must include the copyright notice and this Software
+ License Agreement.
+ b. Copies in binary form must include the copyright notice and this Software
+ License Agreement in the documentation and/or other materials provided with the copy.
+
+4. You may make a copy, or modify a copy or copies of the Software or any
+portion of it, thus forming a work based on the Software, and distribute copies
+outside your organization, if you meet all of the following conditions:
+ a. Copies in source code must include the copyright notice and this
+ Software License Agreement;
+ b. Copies in binary form must include the copyright notice and this
+ Software License Agreement in the documentation and/or other materials
+ provided with the copy;
+ c. Modified copies and works based on the Software must carry prominent
+ notices stating that you changed specified portions of the Software.
+
+5. Portions of the Software resulted from work developed under a U.S. Government
+contract and are subject to the following license: the Government is granted
+for itself and others acting on its behalf a paid-up, nonexclusive, irrevocable
+worldwide license in this computer software to reproduce, prepare derivative
+works, and perform publicly and display publicly.
+
+6. WARRANTY DISCLAIMER. THE SOFTWARE IS SUPPLIED "AS IS" WITHOUT WARRANTY
+OF ANY KIND. THE COPYRIGHT HOLDER, THE UNITED STATES, THE UNITED STATES
+DEPARTMENT OF ENERGY, AND THEIR EMPLOYEES: (1) DISCLAIM ANY WARRANTIES,
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY IMPLIED WARRANTIES
+OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE OR NON-INFRINGEMENT,
+(2) DO NOT ASSUME ANY LEGAL LIABILITY OR RESPONSIBILITY FOR THE ACCURACY,
+COMPLETENESS, OR USEFULNESS OF THE SOFTWARE, (3) DO NOT REPRESENT THAT USE
+OF THE SOFTWARE WOULD NOT INFRINGE PRIVATELY OWNED RIGHTS, (4) DO NOT WARRANT
+THAT THE SOFTWARE WILL FUNCTION UNINTERRUPTED, THAT IT IS ERROR-FREE OR THAT
+ANY ERRORS WILL BE CORRECTED.
+
+7. LIMITATION OF LIABILITY. IN NO EVENT WILL THE COPYRIGHT HOLDER, THE
+UNITED STATES, THE UNITED STATES DEPARTMENT OF ENERGY, OR THEIR EMPLOYEES:
+BE LIABLE FOR ANY INDIRECT, INCIDENTAL, CONSEQUENTIAL, SPECIAL OR PUNITIVE
+DAMAGES OF ANY KIND OR NATURE, INCLUDING BUT NOT LIMITED TO LOSS OF PROFITS
+OR LOSS OF DATA, FOR ANY REASON WHATSOEVER, WHETHER SUCH LIABILITY IS ASSERTED
+ON THE BASIS OF CONTRACT, TORT (INCLUDING NEGLIGENCE OR STRICT LIABILITY), OR
+OTHERWISE, EVEN IF ANY OF SAID PARTIES HAS BEEN WARNED OF THE POSSIBILITY OF
+SUCH LOSS OR DAMAGES.
+The Software was developed at least in part by the University of Chicago,
+as Operator of Argonne National Laboratory (http://miranda.ctd.anl.gov:7123/).
+ */
+import skin.Interface;
+import skin.TextPane;
+import skin.control.SkinPanel;
+
+import java.io.*;
+import java.net.*;
+import java.net.Socket;
+import java.awt.*;
+import java.awt.event.*;
+import java.awt.event.ActionListener;
+import java.awt.event.ActionEvent;
+import java.awt.datatransfer.*;
+import java.applet.*;
+import java.util.*;
+import java.text.*;
+import java.lang.*;
+import javax.swing.*;
+import javax.swing.text.StyledDocument;
+import javax.swing.text.DefaultStyledDocument;
+import javax.swing.text.BadLocationException;
+
+// Workaround for remote JavaScript start method
+import java.security.AccessController;
+import java.security.PrivilegedAction;
+
+
+public class Tcpbw100 extends JApplet implements ActionListener
+{
+ private static final String VERSION = "3.6.3";
+ private static final byte TEST_MID = (1 << 0);
+ private static final byte TEST_C2S = (1 << 1);
+ private static final byte TEST_S2C = (1 << 2);
+ private static final byte TEST_SFW = (1 << 3);
+ private static final byte TEST_STATUS = (1 << 4);
+
+ /* we really should do some clean-up in this java code... maybe later ;) */
+ private static final byte COMM_FAILURE = 0;
+ private static final byte SRV_QUEUE = 1;
+ private static final byte MSG_LOGIN = 2;
+ private static final byte TEST_PREPARE = 3;
+ private static final byte TEST_START = 4;
+ private static final byte TEST_MSG = 5;
+ private static final byte TEST_FINALIZE = 6;
+ private static final byte MSG_ERROR = 7;
+ private static final byte MSG_RESULTS = 8;
+ private static final byte MSG_LOGOUT = 9;
+ private static final byte MSG_WAITING = 10;
+
+ private static final int SFW_NOTTESTED = 0;
+ private static final int SFW_NOFIREWALL = 1;
+ private static final int SFW_UNKNOWN = 2;
+ private static final int SFW_POSSIBLE = 3;
+
+ private static final double VIEW_DIFF = 0.1;
+
+ JTextArea diagnosis, statistics;
+ MyTextPane results;
+ String inresult, outresult, errmsg;
+ JButton startTest;
+
+ // BEGIN by prv
+ JButton stopTest;
+ // END by prv
+
+ JButton disMiss, disMiss2;
+ JButton copy, copy2;
+ JButton deTails;
+ JButton sTatistics;
+ /* BEGIN by prv
+ JButton mailTo;
+ END by prv */
+ JButton options;
+ JCheckBox defaultTest, preferIPv6;
+ JSpinner numOfTests = new JSpinner();
+ String[] delays = { "immediate", "1min","5mins","10mins","30mins","2hours","12hours","1day" };
+ JComboBox delay;
+
+ boolean Randomize, failed, cancopy;
+ URL location;
+ clsFrame f, ff, optionsFrame;
+ String s;
+ double t;
+ int ECNEnabled, NagleEnabled, MSSSent, MSSRcvd;
+ int SACKEnabled, TimestampsEnabled, WinScaleRcvd, WinScaleSent;
+ int FastRetran, AckPktsOut, SmoothedRTT, CurrentCwnd, MaxCwnd;
+ int SndLimTimeRwin, SndLimTimeCwnd, SndLimTimeSender;
+ int SndLimTransRwin, SndLimTransCwnd, SndLimTransSender, MaxSsthresh;
+ int SumRTT, CountRTT, CurrentMSS, Timeouts, PktsRetrans;
+ int SACKsRcvd, DupAcksIn, MaxRwinRcvd, MaxRwinSent;
+ int DataPktsOut, Rcvbuf, Sndbuf, AckPktsIn, DataBytesOut;
+ int PktsOut, CongestionSignals, RcvWinScale;
+ int pkts, lth=8192, CurrentRTO;
+ int c2sData, c2sAck, s2cData, s2cAck;
+ // added for mailto url
+ protected URL targetURL;
+ private String TARGET1 = "U";
+ private String TARGET2 = "H";
+ String emailText;
+ double s2cspd, c2sspd, sc2sspd, ss2cspd;
+ int ssndqueue;
+ double sbytes;
+
+ // BEGIN by prv
+ private boolean _stop;
+ // END by prv
+
+ /*************************************************************************
+ * JavaScript access API extension
+ * Added by Seth Peery and Gregory Wilson, Virginia Tech
+ * October 28, 2009
+ * This section adds classwide variables, written to at runtime,
+ * which are then exposed by public accessor methods that can be called
+ * from web applications using NDT as a back-end.
+ */
+
+ private double pub_c2sspd = 0.0;
+ private double pub_s2cspd = 0.0;
+ private int pub_CurRwinRcvd = 0; // source variable does not exist
+ private int pub_MaxRwinRcvd = 0;
+ private int pub_MinRTT = 0; // source variable does not exist
+ private int pub_MaxRTT = 0; // source variable does not exist
+ private double pub_loss = 0.0;
+ private double pub_avgrtt = 0.0;
+ private int pub_MinRTO = 0; // source variable does not exist
+ private int pub_MaxRTO = 0; // source variable does not exist
+ private int pub_CurRTO = 0;
+ // private String pub_CWNDpeaks = ""; // source variable does not exist
+ private int pub_SACKsRcvd = 0;
+ private String pub_osVer = "unknown";
+ private String pub_javaVer = "unknown";
+ private String pub_host = "unknown";
+ private String pub_osName = "unknown";
+ private String pub_osArch = "unknown";
+ private int pub_mismatch = 0;
+ private int pub_Bad_cable = 0;
+ private int pub_congestion = 0;
+ private double pub_cwndtime = 0.0;
+ private double pub_pctRcvrLimited = 0.0;
+ private String pub_AccessTech = "unknown";
+ private String pub_natBox = "unknown";
+ private int pub_DupAcksOut = 0;
+ private Date pub_TimeStamp;
+ private String pub_isReady = new String("no");
+ private String pub_clientIP = "unknown";
+ private int pub_jitter = 0;
+ private int pub_Timeouts = 0;
+ private String pub_errmsg = "Test not run.";
+ private String isAutoRun;
+
+
+ /**
+ * Accessor methods for public variables
+ **/
+
+ public String get_c2sspd()
+ {
+ // Expressed as MiB using base 10
+ return Double.toString((pub_c2sspd));
+ }
+
+ public String get_s2cspd()
+ {
+ // Expressed as MiB using base 10
+ return Double.toString(pub_s2cspd);
+ }
+
+ public String get_CurRwinRcvd()
+ {
+ return Integer.toString(pub_CurRwinRcvd);
+ }
+
+ public String get_MaxRwinRcvd()
+ {
+ return Integer.toString(pub_MaxRwinRcvd);
+ }
+
+ public String get_Ping()
+ {
+ return Integer.toString(pub_MinRTT);
+ }
+
+ public String get_MaxRTT()
+ {
+ return Integer.toString(pub_MaxRTT);
+ }
+
+ public String get_loss()
+ {
+ return Double.toString(pub_loss);
+ }
+
+ public String get_avgrtt()
+ {
+ return Double.toString(pub_avgrtt);
+ }
+
+ /* public String get_MinRTO()
+ {
+ return pub_MinRTO;
+ }*/
+
+ /* public String get_MaxRTO()
+ {
+ return pub_MaxRTO;
+ }*/
+
+ public String get_CurRTO()
+ {
+ return Integer.toString(pub_CurRTO);
+ }
+
+/*
+ public String get_CWNDpeaks()
+ {
+ return pub_CWNDpeaks;
+ } */
+
+ public String get_SACKsRcvd()
+ {
+ return Integer.toString(pub_SACKsRcvd);
+ }
+
+ public String get_osVer()
+ {
+ return pub_osVer;
+ }
+
+ public String get_javaVer()
+ {
+ return pub_javaVer;
+ }
+
+ public String get_host()
+ {
+ return pub_host;
+ }
+
+ public String get_osName()
+ {
+ return pub_osName;
+ }
+
+ public String get_osArch()
+ {
+ return pub_osArch;
+ }
+
+ public String get_mismatch()
+ {
+ String result;
+ if (pub_mismatch==0) {
+ result = "no";
+ } else {
+ result = "yes";
+ }
+ return result;
+ }
+
+ public String get_Bad_cable()
+ {
+ String result;
+ if (pub_Bad_cable ==1) {
+ result = "yes";
+ } else {
+ result = "no";
+ }
+ return result;
+ }
+
+ public String get_congestion()
+ {
+ String result;
+ if (pub_congestion == 1) {
+ result = "yes";
+ } else {
+ result = "no";
+ }
+ return result;
+ }
+
+ public String get_cwndtime()
+ {
+ return Double.toString(pub_cwndtime);
+ }
+
+ public String get_AccessTech()
+ {
+ return pub_AccessTech;
+ }
+
+ public String get_rcvrLimiting()
+ {
+ return Double.toString(pub_pctRcvrLimited);
+ }
+
+ public String get_optimalRcvrBuffer()
+ {
+ return Integer.toString(pub_MaxRwinRcvd*1024);
+ }
+
+ public String get_clientIP()
+ {
+ return pub_clientIP;
+ }
+
+ public String get_natStatus()
+ {
+ return pub_natBox;
+ }
+
+ public String get_DupAcksOut()
+ {
+ return Integer.toString(pub_DupAcksOut);
+ }
+
+ public String get_TimeStamp()
+ {
+ String result = "unknown";
+ if (pub_TimeStamp != null) {
+ result = pub_TimeStamp.toString();
+ }
+ return result;
+ }
+
+ public String isReady()
+ {
+
+ // if ((pub_isReady == null) || (pub_isReady.equals(""))) {
+ // pub_isReady = "no";
+ // }
+ // String result = "foo";
+
+ //if (failed) {
+ // pub_isReady = "failed1";
+ //}
+ //result = pub_isReady;
+ // return result;
+ return pub_isReady;
+ }
+
+ public String get_jitter()
+ {
+ return Integer.toString((pub_MaxRTT - pub_MinRTT));
+ }
+
+ public String get_WaitSec()
+ {
+ return Integer.toString((pub_CurRTO * pub_Timeouts)/1000);
+ }
+
+ public String get_errmsg()
+ {
+ //String result = "Test not run";
+ //result = pub_errmsg;
+ //return result;
+ return pub_errmsg;
+ }
+
+ // "Remote Control" function - invoke NDT' runtest() method from the API
+ public void run_test()
+ {
+ // The Java security model considers calling a method that opens a socket
+ // from JavaScript to be a privileged action. By using
+ // java.security.privilegedAction here, we can grant JavaScript the
+ // same expanded privileges as the signed applet to open a socket.
+ AccessController.doPrivileged(new PrivilegedAction() {
+ public Object run() {
+ pub_errmsg = "Test in progress.";
+ runtest();
+ return null;
+ }
+ });
+ }
+
+
+/**
+ End of accessor methods
+**/
+ /************************************************************************/
+
+ /**
+ * Added by Martin Sandsmark, UNINETT AS
+ * Internationalization
+ */
+ private Locale locale;
+ private ResourceBundle messages;
+ private String lang="en";
+ private String country="US";
+ //private static String lang="nb";
+ //private static String country="NO";
+ /***/
+
+ int half_duplex, congestion, bad_cable, mismatch;
+ double mylink;
+ double loss, estimate, avgrtt, spd, waitsec, timesec, rttsec;
+ double order, rwintime, sendtime, cwndtime, rwin, swin, cwin;
+ double aspd;
+
+ boolean isApplication = false;
+ boolean testInProgress = false;
+ String host = null;
+ String tmpstr, tmpstr2;
+ byte tests = TEST_MID | TEST_C2S | TEST_S2C | TEST_SFW | TEST_STATUS;
+ int c2sResult = SFW_NOTTESTED;
+ int s2cResult = SFW_NOTTESTED;
+
+ // BEGIN by prv
+ private SkinPanel skinPanel;
+ // END by prv
+
+ public void showStatus(String msg)
+ {
+ if (!isApplication) {
+ super.showStatus(msg);
+ // BEGIN by prv
+ skinPanel.getStatusLabel().setText(msg);
+ // END by prv
+ }
+ }
+
+ public String getParameter(String name)
+ {
+ if (!isApplication) {
+ return super.getParameter(name);
+ }
+ return null;
+ }
+
+
+ // BEGIN by prv
+ public boolean wantToStop() {
+ return _stop;
+ }
+ // END by prv
+
+ public void init() {
+ if (getParameter("country") != null) country = getParameter("country");
+ if (getParameter("language") != null) lang = getParameter("language");
+
+ try {
+ locale = new Locale(lang, country);
+ messages = ResourceBundle.getBundle("Tcpbw100_msgs", locale);
+ } catch (Exception e) {
+ JOptionPane.showMessageDialog(null, "Error while loading language files:\n" + e.getMessage());
+ e.printStackTrace();
+ }
+
+ /* BEGIN by prv
+ getContentPane().setLayout(new BorderLayout());
+ showStatus(messages.getString("ready"));
+ END by prv */
+ failed = false ;
+ Randomize = false;
+ cancopy = false;
+ /* BEGIN by prv
+ results = new MyTextPane();
+ END by prv */
+ // BEGIN by prv
+ Interface skin = Interface.getInstance();
+
+ skinPanel = new SkinPanel(skin);
+ Insets insets = skinPanel.getInsets();
+ results = new MyTextPane(skin.getTextPane(), insets);
+ // END by prv
+
+ // BEGIN by prv
+ startTest = skinPanel.getStartButton();
+ startTest.addActionListener(this);
+ stopTest = skinPanel.getStopButton();
+ stopTest.setEnabled(false);
+
+ stopTest.addActionListener(new ActionListener() {
+
+ public void actionPerformed(ActionEvent e) {
+ if (!_stop && JOptionPane.showConfirmDialog(null, "Are you sure?", "Stop test", JOptionPane.YES_NO_OPTION, JOptionPane.QUESTION_MESSAGE) == JOptionPane.YES_OPTION) {
+ stopTest.setEnabled(false);
+ _stop = true;
+ }
+
+ }
+
+ });
+
+
+ options = skinPanel.getAdvancedButton();
+ options.addActionListener(new ActionListener() {
+
+ public void actionPerformed(ActionEvent e) {
+ options.setEnabled(false);
+ showAdvancedPanel();
+
+ }
+
+ });
+
+ setContentPane(skinPanel);
+ // END by prv
+
+ results.append("TCP/Web100 Network Diagnostic Tool v" + VERSION + "\n");
+ /* BEGIN by prv
+ results.setEditable(false);
+ getContentPane().add(new JScrollPane(results));
+ END by prv */
+ results.append(messages.getString("clickStart") + "\n");
+ /* BEGIN by prv
+ Panel mPanel = new Panel();
+ startTest = new JButton(messages.getString("start"));
+ startTest.addActionListener(this);
+ mPanel.add(startTest);
+ END by prv */
+ sTatistics = new JButton(messages.getString("statistics"));
+ /* BEGIN by prv
+ sTatistics.addActionListener(this);
+ if (getParameter("disableStatistics") == null) {
+ mPanel.add(sTatistics);
+ }
+ sTatistics.setEnabled(false);
+ END by prv */
+ deTails = new JButton(messages.getString("moreDetails"));
+ /* BEGIN by prv
+ deTails.addActionListener(this);
+ if (getParameter("disableDetails") == null) {
+ mPanel.add(deTails);
+ }
+ END by prv */
+ deTails.setEnabled(false);
+ /* BEGIN by prv
+ mailTo = new JButton(messages.getString("reportProblem"));
+ mailTo.addActionListener(this);
+ if (getParameter("disableMailto") == null) {
+ mPanel.add(mailTo);
+ }
+ mailTo.setEnabled(false);
+ options = new JButton(messages.getString("options") + "...");
+ options.addActionListener(new ActionListener() {
+
+ public void actionPerformed(ActionEvent e) {
+ options.setEnabled(false);
+ showOptions();
+ options.setEnabled(true);
+ }
+
+ });
+ if (getParameter("disableOptions") == null) {
+ mPanel.add(options);
+ }
+ getContentPane().add(BorderLayout.SOUTH, mPanel);
+ END by prv */
+ preferIPv6 = new JCheckBox(messages.getString("preferIPv6"));
+ preferIPv6.setSelected(true);
+ defaultTest = new JCheckBox(messages.getString("defaultTests"));
+ defaultTest.setSelected(true);
+ defaultTest.setEnabled(false);
+ SpinnerNumberModel model = new SpinnerNumberModel();
+ model.setMinimum(new Integer(0));
+ model.setValue(new Integer(1));
+ numOfTests.setModel(model);
+ numOfTests.setPreferredSize(new Dimension(60, 20));
+ delay = new JComboBox();
+ for (int i = 0; i < delays.length; i++) {
+ delay.addItem(messages.getString(delays[i]));
+ }
+ delay.setSelectedIndex(0);
+
+ //Autorun functionality
+ isAutoRun = getParameter("autoRun");
+ if ((isAutoRun != null) && isAutoRun.equals("true")) {
+ pub_errmsg = "Test in progress.";
+ runtest();
+ }
+
+ }
+
+
+
+class MyTextPane extends JTextPane
+ {
+ public MyTextPane(final TextPane skin, final Insets insets) {
+
+ setEditable(false);
+
+ final Dimension size = new Dimension(skin.getW(), skin.getH());
+ setPreferredSize(size);
+ setBounds(skin.getX() + insets.left, skin.getY() + insets.top,
+ size.width, size.height);
+ }
+
+ public void append(String text)
+ {
+ try {
+ getStyledDocument().insertString(getStyledDocument().getLength(), text, null);
+ }
+ catch (BadLocationException e) {
+ System.out.println("WARNING: failed to append text to the text pane! [" + text + "]");
+ }
+ }
+
+ public void insertComponent(Component c)
+ {
+ setSelectionStart(results.getStyledDocument().getLength());
+ setSelectionEnd(results.getStyledDocument().getLength());
+ super.insertComponent(c);
+ }
+ }
+
+ private void showAdvancedPanel() {
+ final JDialog dialog = new JDialog();
+ dialog.setTitle("Advanced");
+ JPanel panel = new JPanel(new BorderLayout());
+ panel.add(BorderLayout.CENTER, new JScrollPane(results));
+ JPanel buttonsPanel = new JPanel();
+
+ final JButton optionsButton = new JButton("Options");
+ optionsButton.addActionListener(new ActionListener() {
+ public void actionPerformed(ActionEvent e) {
+ showOptions();
+ }
+ });
+ buttonsPanel.add(optionsButton);
+
+ buttonsPanel.add(deTails);
+
+ JButton btn = new JButton("Close");
+ btn.addActionListener(new ActionListener() {
+ public void actionPerformed(ActionEvent e) {
+ dialog.dispose();
+ }
+ });
+ buttonsPanel.add(btn);
+ panel.add(BorderLayout.SOUTH, buttonsPanel);
+ dialog.addWindowListener(new WindowAdapter() {
+ @Override
+ public void windowClosed(WindowEvent e) {
+ options.setEnabled(true);
+ }
+ });
+ dialog.setContentPane(panel);
+ dialog.setSize(new Dimension(600, 400));
+ dialog.setLocationRelativeTo(null);
+ dialog.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
+ dialog.setVisible(true);
+ }
+
+ class StatusPanel extends JPanel
+ {
+ private int _testNo;
+ private int _testsNum;
+ private boolean _stop = false;
+
+ private JLabel testNoLabel = new JLabel();
+ private JButton stopButton;
+ private JProgressBar progressBar = new JProgressBar();
+
+ StatusPanel(int testsNum) {
+ this._testNo = 1;
+ this._testsNum = testsNum;
+
+ setTestNoLabelText();
+ if (getParameter("enableMultipleTests") != null) {
+ add(testNoLabel);
+ }
+ progressBar.setMinimum(0);
+ progressBar.setMaximum(_testsNum);
+ progressBar.setValue(0);
+ progressBar.setStringPainted(true);
+ if (_testsNum == 0) {
+ progressBar.setString("");
+ progressBar.setIndeterminate(true);
+ }
+ else {
+ progressBar.setString(messages.getString("initialization"));
+ }
+ add(progressBar);
+ stopButton= new JButton(messages.getString("stop"));
+ stopButton.addActionListener(new ActionListener() {
+
+ public void actionPerformed(ActionEvent e) {
+ _stop = true;
+ stopButton.setEnabled(false);
+ StatusPanel.this.setText(messages.getString("stopping"));
+ }
+
+ });
+ if (getParameter("enableMultipleTests") != null) {
+ add(stopButton);
+ }
+ }
+
+ private void setTestNoLabelText() {
+ testNoLabel.setText(messages.getString("test") + " " + _testNo + " " + messages.getString("of") + " " +_testsNum);
+ }
+
+ public boolean wantToStop() {
+ return _stop;
+ }
+
+ public void endTest() {
+ progressBar.setValue(_testNo);
+ _testNo++;
+ setTestNoLabelText();
+ }
+
+ public void setText(String text) {
+ if (!progressBar.isIndeterminate()) {
+ progressBar.setString(text);
+ }
+ }
+ }
+
+ class TestWorker implements Runnable
+ {
+ public void run()
+ {
+ if (!testInProgress) {
+ int testNo = 1;
+ int testsNum = ((Integer)numOfTests.getValue()).intValue();
+ testInProgress = true;
+ diagnose();
+ statistics();
+ startTest.setEnabled(false);
+ // BEGIN by prv
+ stopTest.setEnabled(true);
+ _stop = false;
+ // END by prv
+
+ deTails.setEnabled(false);
+ sTatistics.setEnabled(false);
+ /* BEGIN by prv
+ mailTo.setEnabled(false);
+ options.setEnabled(false);
+ END by prv */
+ numOfTests.setEnabled(false);
+ StatusPanel sPanel = new StatusPanel(testsNum);
+ getContentPane().add(BorderLayout.NORTH, sPanel);
+ getContentPane().validate();
+ getContentPane().repaint();
+
+ try {
+ while (true) {
+ /* BEGIN by prv
+ if (sPanel.wantToStop()) {
+ END by prv */
+ if (sPanel.wantToStop() || wantToStop()) {
+ break;
+ }
+ if (testsNum == 0) {
+ results.append("\n** " + messages.getString("startingTest") + " " + testNo + " **\n");
+ }
+ else {
+ results.append("\n** " + messages.getString("startingTest") + " " + testNo + " " + messages.getString("of") + " " + testsNum + " **\n");
+ }
+ dottcp(sPanel);
+ if (testNo == testsNum) {
+ break;
+ }
+ /* BEGIN by prv
+ if (sPanel.wantToStop()) {
+ END by prv */
+ if (sPanel.wantToStop() || wantToStop()) {
+ break;
+ }
+ sPanel.setText("");
+ sPanel.endTest();
+ testNo += 1;
+ deTails.setEnabled(true);
+ sTatistics.setEnabled(true);
+ /* BEGIN by prv
+ mailTo.setEnabled(true);
+ options.setEnabled(true);
+ END by prv */
+ statistics.append("\n** " + messages.getString("test") + " " + testNo + " **\n");
+ diagnosis.append("\n** " + messages.getString("test") + " " + testNo + " **\n");
+ try {
+ switch (delay.getSelectedIndex()) {
+ case 1:
+ results.append("\n** " + messages.getString("sleep1m") + " **\n");
+ Thread.sleep(1000 * 60);
+ break;
+ case 2:
+ results.append("\n** " + messages.getString("sleep5m") + " **\n");
+ Thread.sleep(1000 * 60 * 5);
+ break;
+ case 3:
+ results.append("\n** " + messages.getString("sleep10m") + " **\n");
+ Thread.sleep(1000 * 60 * 10);
+ break;
+ case 4:
+ results.append("\n** " + messages.getString("sleep30m") + " **\n");
+ Thread.sleep(1000 * 60 * 30);
+ break;
+ case 5:
+ results.append("\n** " + messages.getString("sleep2h") + " **\n");
+ Thread.sleep(1000 * 60 * 120);
+ break;
+ case 6:
+ results.append("\n** " + messages.getString("sleep12h") + " **\n");
+ Thread.sleep(1000 * 60 * 720);
+ break;
+ case 7:
+ results.append("\n** " + messages.getString("sleep1d") + " **\n");
+ Thread.sleep(1000 * 60 * 1440);
+ break;
+ }
+ }
+ catch (InterruptedException e) {
+ // do nothing.
+ }
+ }
+ } catch(IOException e) {
+ e.printStackTrace();
+ failed=true;
+ errmsg = messages.getString("serverBusy30s") + "\n";
+ }
+
+ if (failed) {
+ results.append(errmsg);
+ // BEGIN by prv
+ showStatus(Interface.getInstance().getStopString());
+ // END by prv
+
+ pub_isReady = "failed";
+ pub_errmsg = errmsg;
+ }
+ // BEGIN by prv
+ else {
+ showStatus(Interface.getInstance().getCompleteTestString());
+ }
+ // END by prv
+
+ deTails.setEnabled(true);
+ sTatistics.setEnabled(true);
+ /* BEGIN by prv
+ mailTo.setEnabled(true);
+ options.setEnabled(true);
+ END by prv */
+ // BEGIN by prv
+ skinPanel.setValue1_(0);
+ skinPanel.setValue2_(0);
+ // END by prv
+ numOfTests.setEnabled(true);
+ /* BEGIN by prv
+ showStatus(messages.getString("done2"));
+ END by prv */
+ results.append("\n" + messages.getString("clickStart2") + "\n");
+ startTest.setEnabled(true);
+ // BEGIN by prv
+ stopTest.setEnabled(false);
+ // END by prv
+ testInProgress = false;
+ getContentPane().remove(sPanel);
+ getContentPane().validate();
+ getContentPane().repaint();
+ }
+ }
+ }
+
+ synchronized public void runtest() {
+ new Thread(new TestWorker()).start();
+ }
+
+ class Message {
+ byte type;
+ byte[] body;
+ }
+
+ class Protocol {
+ private InputStream _ctlin;
+ private OutputStream _ctlout;
+
+ public Protocol(Socket ctlSocket) throws IOException
+ {
+ _ctlin = ctlSocket.getInputStream();
+ _ctlout = ctlSocket.getOutputStream();
+ }
+
+ public void send_msg(byte type, byte toSend) throws IOException
+ {
+ byte[] tab = new byte[] { toSend };
+ send_msg(type, tab);
+ }
+
+ public void send_msg(byte type, byte[] tab) throws IOException
+ {
+ byte[] header = new byte[3];
+ header[0] = type;
+ header[1] = (byte) (tab.length >> 8);
+ header[2] = (byte) tab.length;
+
+ _ctlout.write(header);
+ _ctlout.write(tab);
+ }
+
+ public int readn(Message msg, int amount) throws IOException
+ {
+ int read = 0;
+ int tmp;
+ msg.body = new byte[amount];
+ while (read != amount) {
+ tmp = _ctlin.read(msg.body, read, amount - read);
+ if (tmp <= 0) {
+ return read;
+ }
+ read += tmp;
+ }
+ return read;
+ }
+
+ public int recv_msg(Message msg) throws IOException
+ {
+ int length;
+ if (readn(msg, 3) != 3) {
+ return 1;
+ }
+ msg.type = msg.body[0];
+ length = ((int) msg.body[1] & 0xFF) << 8;
+ length += (int) msg.body[2] & 0xFF;
+ if (readn(msg, length) != length) {
+ return 3;
+ }
+ return 0;
+ }
+
+ public void close()
+ {
+ try {
+ _ctlin.close();
+ _ctlout.close();
+ }
+ catch (IOException e) {
+ e.printStackTrace();
+ }
+ }
+ }
+
+ public boolean test_mid(Protocol ctl) throws IOException
+ {
+ byte buff[] = new byte[8192];
***The diff for this file has been truncated for email.***
=======================================
--- /dev/null
+++ /branches/SamKnows/src/Tcpbw100.patch Tue Jun 1 09:44:58 2010
@@ -0,0 +1,609 @@
+--- Tcpbw100.java.orig 2010-04-13 03:02:45.000000000 +0400
++++ Tcpbw100.java 2010-05-29 20:54:58.975941500 +0400
+@@ -59,6 +59,10 @@
+ The Software was developed at least in part by the University of Chicago,
+ as Operator of Argonne National Laboratory (http://miranda.ctd.anl.gov:7123/).
+ */
++import skin.Interface;
++import skin.TextPane;
++import skin.control.SkinPanel;
++
+ import java.io.*;
+ import java.net.*;
+ import java.net.Socket;
+@@ -71,25 +75,10 @@
+ import java.util.*;
+ import java.text.*;
+ import java.lang.*;
+-import javax.swing.JLabel;
+-import javax.swing.JApplet;
+-import javax.swing.JFrame;
+-import javax.swing.JTextArea;
+-import javax.swing.JButton;
+-import javax.swing.JCheckBox;
+-import javax.swing.JPanel;
+-import javax.swing.JScrollPane;
+-import javax.swing.BorderFactory;
+-import javax.swing.JTextPane;
++import javax.swing.*;
+ import javax.swing.text.StyledDocument;
+ import javax.swing.text.DefaultStyledDocument;
+ import javax.swing.text.BadLocationException;
+-import javax.swing.JOptionPane;
+-import javax.swing.BoxLayout;
+-import javax.swing.JSpinner;
+-import javax.swing.SpinnerNumberModel;
+-import javax.swing.JComboBox;
+-import javax.swing.JProgressBar;
+
+ // Workaround for remote JavaScript start method
+ import java.security.AccessController;
+@@ -129,11 +118,18 @@
+ MyTextPane results;
+ String inresult, outresult, errmsg;
+ JButton startTest;
++
++ // BEGIN by prv
++ JButton stopTest;
++ // END by prv
++
+ JButton disMiss, disMiss2;
+ JButton copy, copy2;
+ JButton deTails;
+ JButton sTatistics;
++ /* BEGIN by prv
+ JButton mailTo;
++ END by prv */
+ JButton options;
+ JCheckBox defaultTest, preferIPv6;
+ JSpinner numOfTests = new JSpinner();
+@@ -165,6 +161,10 @@
+ int ssndqueue;
+ double sbytes;
+
++ // BEGIN by prv
++ private boolean _stop;
++ // END by prv
++
+ /*************************************************************************
+ * JavaScript access API extension
+ * Added by Seth Peery and Gregory Wilson, Virginia Tech
+@@ -465,10 +465,17 @@
+ int c2sResult = SFW_NOTTESTED;
+ int s2cResult = SFW_NOTTESTED;
+
++ // BEGIN by prv
++ private SkinPanel skinPanel;
++ // END by prv
++
+ public void showStatus(String msg)
+ {
+ if (!isApplication) {
+ super.showStatus(msg);
++ // BEGIN by prv
++ skinPanel.getStatusLabel().setText(msg);
++ // END by prv
+ }
+ }
+
+@@ -481,6 +488,12 @@
+ }
+
+
++ // BEGIN by prv
++ public boolean wantToStop() {
++ return _stop;
++ }
++ // END by prv
++
+ public void init() {
+ if (getParameter("country") != null) country = getParameter("country");
+ if (getParameter("language") != null) lang = getParameter("language");
+@@ -493,32 +506,86 @@
+ e.printStackTrace();
+ }
+
++ /* BEGIN by prv
+ getContentPane().setLayout(new BorderLayout());
+ showStatus(messages.getString("ready"));
++ END by prv */
+ failed = false ;
+ Randomize = false;
+ cancopy = false;
++ /* BEGIN by prv
+ results = new MyTextPane();
++ END by prv */
++ // BEGIN by prv
++ Interface skin = Interface.getInstance();
++
++ skinPanel = new SkinPanel(skin);
++ Insets insets = skinPanel.getInsets();
++ results = new MyTextPane(skin.getTextPane(), insets);
++ // END by prv
++
++ // BEGIN by prv
++ startTest = skinPanel.getStartButton();
++ startTest.addActionListener(this);
++ stopTest = skinPanel.getStopButton();
++ stopTest.setEnabled(false);
++
++ stopTest.addActionListener(new ActionListener() {
++
++ public void actionPerformed(ActionEvent e) {
++ if (!_stop && JOptionPane.showConfirmDialog(null, "Are you sure?", "Stop test", JOptionPane.YES_NO_OPTION, JOptionPane.QUESTION_MESSAGE) == JOptionPane.YES_OPTION) {
++ stopTest.setEnabled(false);
++ _stop = true;
++ }
++
++ }
++
++ });
++
++
++ options = skinPanel.getAdvancedButton();
++ options.addActionListener(new ActionListener() {
++
++ public void actionPerformed(ActionEvent e) {
++ options.setEnabled(false);
++ showAdvancedPanel();
++
++ }
++
++ });
++
++ setContentPane(skinPanel);
++ // END by prv
++
+ results.append("TCP/Web100 Network Diagnostic Tool v" + VERSION + "\n");
++ /* BEGIN by prv
+ results.setEditable(false);
+ getContentPane().add(new JScrollPane(results));
++ END by prv */
+ results.append(messages.getString("clickStart") + "\n");
++ /* BEGIN by prv
+ Panel mPanel = new Panel();
+ startTest = new JButton(messages.getString("start"));
+ startTest.addActionListener(this);
+ mPanel.add(startTest);
++ END by prv */
+ sTatistics = new JButton(messages.getString("statistics"));
++ /* BEGIN by prv
+ sTatistics.addActionListener(this);
+ if (getParameter("disableStatistics") == null) {
+ mPanel.add(sTatistics);
+ }
+ sTatistics.setEnabled(false);
++ END by prv */
+ deTails = new JButton(messages.getString("moreDetails"));
++ /* BEGIN by prv
+ deTails.addActionListener(this);
+ if (getParameter("disableDetails") == null) {
+ mPanel.add(deTails);
+ }
++ END by prv */
+ deTails.setEnabled(false);
++ /* BEGIN by prv
+ mailTo = new JButton(messages.getString("reportProblem"));
+ mailTo.addActionListener(this);
+ if (getParameter("disableMailto") == null) {
+@@ -539,6 +606,7 @@
+ mPanel.add(options);
+ }
+ getContentPane().add(BorderLayout.SOUTH, mPanel);
++ END by prv */
+ preferIPv6 = new JCheckBox(messages.getString("preferIPv6"));
+ preferIPv6.setSelected(true);
+ defaultTest = new JCheckBox(messages.getString("defaultTests"));
+@@ -568,6 +636,16 @@
+
+ class MyTextPane extends JTextPane
+ {
++ public MyTextPane(final TextPane skin, final Insets insets) {
++
++ setEditable(false);
++
++ final Dimension size = new Dimension(skin.getW(), skin.getH());
++ setPreferredSize(size);
++ setBounds(skin.getX() + insets.left, skin.getY() + insets.top,
++ size.width, size.height);
++ }
++
+ public void append(String text)
+ {
+ try {
+@@ -586,6 +664,44 @@
+ }
+ }
+
++ private void showAdvancedPanel() {
++ final JDialog dialog = new JDialog();
++ dialog.setTitle("Advanced");
++ JPanel panel = new JPanel(new BorderLayout());
++ panel.add(BorderLayout.CENTER, new JScrollPane(results));
++ JPanel buttonsPanel = new JPanel();
++
++ final JButton optionsButton = new JButton("Options");
++ optionsButton.addActionListener(new ActionListener() {
++ public void actionPerformed(ActionEvent e) {
++ showOptions();
++ }
++ });
++ buttonsPanel.add(optionsButton);
++
++ buttonsPanel.add(deTails);
++
++ JButton btn = new JButton("Close");
++ btn.addActionListener(new ActionListener() {
++ public void actionPerformed(ActionEvent e) {
++ dialog.dispose();
++ }
++ });
++ buttonsPanel.add(btn);
++ panel.add(BorderLayout.SOUTH, buttonsPanel);
++ dialog.addWindowListener(new WindowAdapter() {
++ @Override
++ public void windowClosed(WindowEvent e) {
++ options.setEnabled(true);
++ }
++ });
++ dialog.setContentPane(panel);
++ dialog.setSize(new Dimension(600, 400));
++ dialog.setLocationRelativeTo(null);
++ dialog.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
++ dialog.setVisible(true);
++ }
++
+ class StatusPanel extends JPanel
+ {
+ private int _testNo;
+@@ -663,10 +779,17 @@
+ diagnose();
+ statistics();
+ startTest.setEnabled(false);
++ // BEGIN by prv
++ stopTest.setEnabled(true);
++ _stop = false;
++ // END by prv
++
+ deTails.setEnabled(false);
+ sTatistics.setEnabled(false);
++ /* BEGIN by prv
+ mailTo.setEnabled(false);
+ options.setEnabled(false);
++ END by prv */
+ numOfTests.setEnabled(false);
+ StatusPanel sPanel = new StatusPanel(testsNum);
+ getContentPane().add(BorderLayout.NORTH, sPanel);
+@@ -675,7 +798,10 @@
+
+ try {
+ while (true) {
++ /* BEGIN by prv
+ if (sPanel.wantToStop()) {
++ END by prv */
++ if (sPanel.wantToStop() || wantToStop()) {
+ break;
+ }
+ if (testsNum == 0) {
+@@ -688,7 +814,10 @@
+ if (testNo == testsNum) {
+ break;
+ }
++ /* BEGIN by prv
+ if (sPanel.wantToStop()) {
++ END by prv */
++ if (sPanel.wantToStop() || wantToStop()) {
+ break;
+ }
+ sPanel.setText("");
+@@ -696,8 +825,10 @@
+ testNo += 1;
+ deTails.setEnabled(true);
+ sTatistics.setEnabled(true);
++ /* BEGIN by prv
+ mailTo.setEnabled(true);
+ options.setEnabled(true);
++ END by prv */
+ statistics.append("\n** " + messages.getString("test") + " " + testNo + " **\n");
+ diagnosis.append("\n** " + messages.getString("test") + " " + testNo + " **\n");
+ try {
+@@ -744,19 +875,38 @@
+
+ if (failed) {
+ results.append(errmsg);
++ // BEGIN by prv
++ showStatus(Interface.getInstance().getStopString());
++ // END by prv
+
+ pub_isReady = "failed";
+ pub_errmsg = errmsg;
+ }
++ // BEGIN by prv
++ else {
++ showStatus(Interface.getInstance().getCompleteTestString());
++ }
++ // END by prv
+
+ deTails.setEnabled(true);
+ sTatistics.setEnabled(true);
++ /* BEGIN by prv
+ mailTo.setEnabled(true);
+ options.setEnabled(true);
++ END by prv */
++ // BEGIN by prv
++ skinPanel.setValue1_(0);
++ skinPanel.setValue2_(0);
++ // END by prv
+ numOfTests.setEnabled(true);
++ /* BEGIN by prv
+ showStatus(messages.getString("done2"));
++ END by prv */
+ results.append("\n" + messages.getString("clickStart2") + "\n");
+ startTest.setEnabled(true);
++ // BEGIN by prv
++ stopTest.setEnabled(false);
++ // END by prv
+ testInProgress = false;
+ getContentPane().remove(sPanel);
+ getContentPane().validate();
+@@ -851,7 +1001,9 @@
+ /* now look for middleboxes (firewalls, NATs, and other boxes that
+ * muck with TCP's end-to-end priciples
+ */
++ /* BEGIN by prv
+ showStatus(messages.getString("middleboxTest"));
++ END by prv */
+ results.append(messages.getString("checkingMiddleboxes") + " ");
+ statistics.append(messages.getString("checkingMiddleboxes") + " ");
+ emailText = messages.getString("checkingMiddleboxes") + " ";
+@@ -967,7 +1119,10 @@
+ {
+ Message msg = new Message();
+ if ((tests & TEST_SFW) == TEST_SFW) {
++ /* BEGIN by prv
+ showStatus(messages.getString("sfwTest"));
++ END by prv */
++ showStatus(Interface.getInstance().getFirewallTestString());
+ results.append(messages.getString("checkingFirewalls") + " ");
+ statistics.append(messages.getString("checkingFirewalls") + " ");
+ emailText = messages.getString("checkingFirewalls") + " ";
+@@ -1083,7 +1238,10 @@
+ byte buff2[] = new byte[64*1024];
+ Message msg = new Message();
+ if ((tests & TEST_C2S) == TEST_C2S) {
++ /* BEGIN by prv
+ showStatus(messages.getString("outboundTest"));
++ END by prv */
++ showStatus(Interface.getInstance().getUploadTestString());
+ results.append(messages.getString("runningOutboundTest") + " ");
+ statistics.append(messages.getString("runningOutboundTest") + " ");
+ emailText += messages.getString("runningOutboundTest") + " ";
+@@ -1158,6 +1316,11 @@
+ break;
+ }
+ pkts++;
++ // BEGIN by prv
++ if (System.currentTimeMillis() - t > 0) {
++ skinPanel.setValue2((int) ((8.0 * pkts * lth) / (System.currentTimeMillis() - t)));
++ }
++ //END by prv
+ } while (System.currentTimeMillis() < stop_time);
+
+ t = System.currentTimeMillis() - t;
+@@ -1194,6 +1357,10 @@
+ emailText += prtdbl(sc2sspd) + "Mb/s\n%0A";
+ }
+
++ // BEGIN by prv
++ skinPanel.setValue2((int) (sc2sspd * 1000));
++ // END by prv
++
+ // Expose upload speed to JavaScript clients
+ pub_c2sspd = sc2sspd;
+
+@@ -1217,7 +1384,10 @@
+ byte buff[] = new byte[8192];
+ Message msg = new Message();
+ if ((tests & TEST_S2C) == TEST_S2C) {
++ /* BEGIN by prv
+ showStatus(messages.getString("inboundTest"));
++ END by prv */
++ showStatus(Interface.getInstance().getDownloadTestString());
+ results.append(messages.getString("runningInboundTest") + " ");
+ statistics.append(messages.getString("runningInboundTest") + " ");
+ emailText += messages.getString("runningInboundTest") + " ";
+@@ -1275,6 +1445,10 @@
+ bytes += inlth;
+ if ((System.currentTimeMillis() - t) > 14500)
+ break;
++ // BEGIN by prv
++ if (System.currentTimeMillis() - t > 0)
++ skinPanel.setValue1((int) ((8.0 * bytes) / (System.currentTimeMillis() - t)));
++ // END by prv
+ }
+ }
+ catch (IOException e) {}
+@@ -1283,6 +1457,10 @@
+ System.out.println(bytes + " bytes " + (8.0 * bytes)/t + " kb/s " + t/1000 + " secs");
+ s2cspd = ((8.0 * bytes) / 1000) / t;
+
++ // BEGIN by prv
++ skinPanel.setValue1((int) ((8.0 * bytes) / t));
++ // END by prv
++
+ /* receive the s2cspd from the server */
+ if (ctl.recv_msg(msg) != 0) {
+ errmsg = messages.getString("protocolError") + Integer.parseInt(new String(msg.body), 16) + " instead\n";
+@@ -1487,6 +1665,9 @@
+ // tests in the queue.
+ wait = (wait * 45);
+ results.append(messages.getString("otherClient") + wait + messages.getString("seconds") +".\n");
++ // BEGIN prv
++ showStatus(Interface.getInstance().getWaitString());
++ // END prv
+ swait = 1;
+ }
+
+@@ -1525,7 +1706,10 @@
+ StringTokenizer tokenizer = new StringTokenizer(new String(msg.body), " ");
+
+ while (tokenizer.hasMoreTokens()) {
++ /* BEGIN by prv
+ if (sPanel.wantToStop()) {
++ END by prv */
++ if (sPanel.wantToStop() || wantToStop()) {
+ ctl.send_msg(MSG_ERROR, "Manually stopped by the user".getBytes());
+ ctl.close();
+ ctlSocket.close();
+@@ -1558,14 +1742,37 @@
+ results.append(messages.getString("c2sThroughputFailed") + "\n");
+ tests &= (~TEST_C2S);
+ }
++ // BEGIN by prv
++ try {
++ Thread.sleep(3000);
++ } catch (InterruptedException e) {
++ }
++ skinPanel.setValue2_(0);
++ try {
++ Thread.sleep(1000);
++ } catch (InterruptedException e) {
++ }
++ // END by prv
+ break;
+ case TEST_S2C:
++ // BEGIN by prv
++ try {
++ Thread.sleep(1000);
++ } catch (InterruptedException e) {
++ }
++ // END by prv
+ sPanel.setText(messages.getString("s2cThroughput"));
+ if (test_s2c(ctl, ctlSocket)) {
+ results.append(errmsg);
+ results.append(messages.getString("s2cThroughputFailed") + "\n");
+ tests &= (~TEST_S2C);
+ }
++ // BEGIN by prv
++ try {
++ Thread.sleep(1000);
++ } catch (InterruptedException e) {
++ }
++ // END by prv
+ break;
+ default:
+ errmsg = messages.getString("unknownID") + "\n";
+@@ -1573,7 +1780,10 @@
+ return;
+ }
+ }
++ /* BEGIN by prv
+ if (sPanel.wantToStop()) {
++ END by prv */
++ if (sPanel.wantToStop() || wantToStop()) {
+ ctl.send_msg(MSG_ERROR, "Manually stopped by the user".getBytes());
+ ctl.close();
+ ctlSocket.close();
+@@ -1637,6 +1847,21 @@
+ middleboxResults(tmpstr2);
+ }
+
++ // BEGIN by prv
++ skinPanel.setRtt(avgrtt);
++ skinPanel.setLoss(loss);
++
++ StringBuilder sb = new StringBuilder();
++ sb.append("sessionid=").append(URLEncoder.encode(getParameter("sessionid"), "UTF-8")).append('&');
++ sb.append("avgrtt=").append(URLEncoder.encode(String.valueOf(avgrtt), "UTF-8")).append('&');
++ sb.append("loss=").append(URLEncoder.encode(String.valueOf(loss), "UTF-8")).append('&');
++ sb.append("upload=").append(URLEncoder.encode(String.valueOf(sc2sspd), "UTF-8")).append('&');
++ // sb.append("upload=").append(URLEncoder.encode(String.valueOf(c2sspd), "UTF-8")).append('&');
++ sb.append("download=").append(URLEncoder.encode(String.valueOf(s2cspd), "UTF-8")).append('\n');
++ System.out.println("Request: " + sb.toString());
++ sendPostRequest(getParameter("resultServer"), sb.toString());
++ // END by prv
++
+ pub_isReady="yes";
+ pub_errmsg ="All tests completed OK.";
+ }
+@@ -2518,7 +2743,9 @@
+
+
+ public void diagnose() {
++ /* BEGIN by prv
+ showStatus(messages.getString("getWeb100Var"));
++ END by prv */
+
+ if (f == null) {
+ f = new clsFrame();
+@@ -2547,7 +2774,9 @@
+
+
+ public void statistics() {
++ /* BEGIN by prv
+ showStatus(messages.getString("printDetailedStats"));
++ END by prv */
+
+ if (ff == null) {
+ ff = new clsFrame();
+@@ -2649,6 +2878,14 @@
+ ff.dispose();
+ ff = null;
+ }
++ // BEGIN by prv
++ _stop = false;
++ skinPanel.setValue1(0);
++ skinPanel.setValue2(0);
++ skinPanel.setRtt(0f);
++ skinPanel.setLoss(0f);
++ showStatus(Interface.getInstance().getPreparingTestString());
++ // END by prv
+
+ pub_errmsg = "Test in progress.";
+ runtest();
+@@ -2699,6 +2936,7 @@
+ sTatistics.setEnabled(true);
+ }
+
++ /* BEGIN by prv
+ else if (source == mailTo) {
+ int i;
+ char key;
+@@ -2735,6 +2973,7 @@
+
+ getAppletContext().showDocument(targetURL);
+ }
++ END by prv */
+ } // actionPerformed()
+
+
+@@ -2773,4 +3012,29 @@
+ frame.setVisible(true);
+ }
+
++ // BEGIN by prv
++ // send a POST request to Web server
++
++ public void sendPostRequest(String url, String message) {
++ try {
++ System.out.println("Send report to: " + url);
++ URLConnection connection = new URL(url).openConnection();
++ connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded;charset=utf-8");
++ connection.setDoOutput(true);
++ BufferedWriter out = new BufferedWriter(new OutputStreamWriter(connection.getOutputStream()));
++ out.write(message);
++ out.flush();
++ out.close();
++
++ BufferedInputStream in = new BufferedInputStream(connection.getInputStream());
++ while (in.read() != -1) ;
++ System.out.println();
++ in.close();
++
++ } catch (Exception e) {
++ e.printStackTrace();
++ }
++ }
++ // END by prv
++
+ } // class: Tcpbw100
=======================================
--- /dev/null
+++ /branches/SamKnows/src/Tcpbw100_msgs_ca_ES.properties Tue Jun 1 09:44:58 2010
@@ -0,0 +1,220 @@
+10gbps = subxarxa 10 Gbps 10 Gigabit Ethernet/OC-192
+10mbps = subxarxa 10 Mbps Ethernet
+10mins = 10 min
+12hours = 12 hores
+1day = 1 dia
+1gbps = subxarxa 1.0 Gbps Gigabit Ethernet
+1min = 1 min
+2.4gbps = subxarxa 2.4 Gbps OC-48
+2hours = 2 hores
+30mins = 30 min
+45mbps = subxarxa 45 Mbps T3/DS3
+5mins = 5 min
+622mbps = subxarxa a 622 Mbps OC-12
+and = and
+architecture = Arquitectura
+bytes = Bytes
+c2s = C2S
+c2sPacketQueuingDetected = [C2S]: Cua de paquets detectada
+c2sThroughput = C2S throughput
+c2sThroughputFailed = Test de C2S throughput FALLIT!
+cabledsl = Cable/DSL modem
+cablesNok = Advert\u00e8ncia: Excessius errors de xarxa, revisar cable(s) de xarxa
+cablesOk = Trobat bon(s) cable(s) de xarxa
+checkingFirewalls = Buscant Firewalls . . . . . . . . . . . . . . . . . . .
+checkingMiddleboxes = Buscant Caixes Intermitjes (Middleboxes) . . . . . . . . . . . . . . . . . .
+clickStart = Fes click a COMEN\u00e7AR per a comen\u00e7ar la prova
+clickStart2 = Fes click a COMEN\u00e7AR per a tornar a fer la prova
+client = Client
+client2 = Client
+clientAcksReport = Client Confirma l'enlla\u00e7 reportat \u00e9s
+clientDataReports = Dades de Client reporten que l'enlla\u00e7 \u00e9s
+clientInfo = Detalls del sistema client
+clientIpModified = Informaci\u00f3: El NAT (Network Address Translation) est\u00e0 modificant l'adre\u00e7a IP del client
+clientIpNotFound = No es troba l'adre\u00e7a del client. Per a usuaris d'Internet Explorer, modifiqui els par\u00e0metres de Java\n Click a Eines - Opcions d'Internet - Seguretat - Nivell personalitzat, trobi la l\u00ednia\n Microsoft VM - Java Permissions i faci click a personalitzar\ Editar permisos - Acc\u00e9s a totes les Adreces de xarxa, click a Habilitar i desar els canvis.
+clientIpPreserved = Les Adreces IP de servidor son conservades Extrem-a-Extrem
+clientSays = per\u00f2 el Client diu
+close = Tancar
+comments = Comentaris
+congestNo = No s'ha trobat congesti\u00f3 de xarxa
+congestYes = Informaci\u00f3: El throughput \u00e9s limitat per altre tr\u00e0fic de xarxa
+connIdle = La connexi\u00f3 estaba aturada
+connStalled = La connexi\u00f3 s'ha pausat
+connected = Connectat a:
+connectedTo = s'ha connectat a:
+copy = C\u00f2pia
+defaultTests = Proves per defecte
+delayBetweenTests = Retard entre proves
+detailedStats = Estad\u00edstiques detallades
+dialup = Modem telef\u00f2nic
+dialup2 = Trucada
+done = Fet.
+done2 = Tcpbw100 fet
+dupAcksIn = es reben ack's duplicats
+duplexFullHalf = Alarma: Condici\u00f3 doble no concordant detectada Switch=Full i Host=half
+duplexHalfFull = Alarma: Condici\u00f3 doble no concordant detectada Switch=half i Host=full
+duplexNok = Advert\u00e8ncia: Condici\u00f3 doble antiga no concordant antiga
+duplexOk = Operaci\u00f3 normal trobada (Normal duplex operation found.)
+endOfEmail = Final del missatge de Correu electr\u00f2nic
+excLoss = Exc\u00e9s de p\u00e8rdua de paquets est\u00e0 impactant al rendiment, prova la funci\u00f3 d'autonegociaci\u00f3 entre el teu PC i el switch de xarxa
+excessiveErrors = Alarma: Excessius errors, revisa el(s) cable(s) de xarxa.
+firewallNo = no est\u00e0 darrere un firewall. [Conexi\u00f3 al port ef\u00edmer correcte]
+firewallYes = est\u00e0 probablement darrere un firewall. [Conexi\u00f3 al port ef\u00edmer ha fallat]
+flowControlLimits = El control de fluxe basat en xarxa limita el throughput a
+found100mbps = Trobat enlla\u00e7 de 100 Mbps FastEthernet.
+found10gbps = Trobat enlla\u00e7 de 10 Gbps 10 GigEthernet/OC-192.
+found10mbps = Trobat enlla\u00e7 de 10 Mbps Ethernet.
+found1gbps = Trobat enlla\u00e7 de 1 Gbps GigabitEthernet.
+found2.4gbps = Trobat enlla\u00e7 de 2.4 Gbps OC-48.
+found45mbps = Trobat enlla\u00e7 de 45 Mbps T3/DS3.
+found622mbps = Trobat enlla\u00e7 de 622 Mbps OC-12.
+foundDialup = Trobat enlla\u00e7 de Dial-up modem.
+foundDsl = Trobat enlla\u00e7 de Cable modem/DSL/T1.
+fullDuplex = subxaxarxa Full duplex Fast Ethernet
+general = General
+generatingReport = Generant informe de problemes: Aquest informe s'enviar\u00e0 per e-mail a la persona que especifiquis
+getWeb100Var = Obt\u00e9 les variables WEB100
+halfDuplex = subxarxa Half duplex Fast Ethernet
+id = Eina de diagn\u00f2stic de xara TCP/Web100
+immediate = immediat
+inboundTest = Test d'entrada Tcpbw100...
+inboundWrongMessage = Test de throughput C2S: Rebut un tipus de missatge erroni
+incompatibleVersion = N\u00famero de versi\u00f3 incompatible
+incrRxBuf = Augmentant el valor del buffer de recepci\u00f3 del client
+incrTxBuf = Augmentant el buffer de sortida del servidor NDT
+information = Informaci\u00f3
+initialization = Inicialitzant...
+insufficient = No es disposa de prou dades per a determinar el tipus d'enlla\u00e7.
+invokingMailtoFunction = Invocant funci\u00f3 Mailto Tcpbw100
+ipProtocol = Protocol IP
+ipcFail = Fallen les comunicacions entre processos, tipus d'enlla\u00e7 desconegut.
+usingIpv4 = -- Utilitzant adre\u00e7a IPv4
+usingIpv6 = -- Utilitzant adre\u00e7a IPv6
+javaData = Dades Java
+kbyteBufferLimits = KByte buffer que limita el throughput a
+limitNet = Xarxa limitada
+limitRx = Receptor limitat
+limitTx = Emissor limitat
+linkFullDpx = Enlla\u00e7 establert al mode Full Duplex
+linkHalfDpx = Enlla\u00e7 establert al mode Half Duplex
+loggingWrongMessage = Logant al servidor: Es rep un tipus de missatge erroni.
+lookupError = Incapa\u00e7 d'obtenir la adre\u00e7a IP remota
+mboxWrongMessage = Test intermig: Rebut tipus de missatge erroni
+middlebox = Middlebox
+middleboxFail = El servidor ha fallat mentre es provaba la middlebox
+middleboxFail2 = test Middlebox FALLA!
+middleboxModifyingMss = Informaci\u00f3: La middlebox de xarxa est\u00e0 modificant la variable MSS
+middleboxTest = Test de Middlebox Tcpbw100...
+moreDetails = M\u00e9s detalls...
+name = Nom
+ndtServerHas = El servidor NDT t\u00e9 un
+noPktLoss1 = No hi ha p\u00e8rdua de paquets
+noPktLoss2 = No s'aprecia cap p\u00e8rdua de paquets
+numberOfTests = Nombre de proves
+of = de
+off = OFF
+ok = OK
+oldDuplexMismatch = "Advert\u00e8ncia: Es detecta antiga condici\u00f3 doble no concordant"
+on = ON
+ooOrder = per\u00f2 els paquets han arribat desordenats
+options = Opcions
+osData = dades del SO:
+otherClient = S'est\u00e0 servint un altre client, la seva prova comen\u00e7ar\u00e0 en
+otherTraffic = Informaci\u00f3: L'enlla\u00e7 de xarxa est\u00e0 congestionat per algun altre tr\u00e0fic
+outboundTest = Test de sortida Tcpbw100...
+outboundWrongMessage = Test de throughput C2S: Es rep un tipus de missatge erroni
+packetQueuing = Posant paquets en cua
+packetQueuingInfo = TCP (Transmission Control Protocol) transfereix dades entre dos\n equips d'internet. Autom\u00e0ticament detecta i es recupera d'errors i p\u00e8rdues./n TCP utilitza buffers per a proporcionar aquesta confiabilitat. Adem\u00e9s,\n els switch i routers
+utilitzen buffers per aquells casos en que m\u00faltiples enlla\u00e7os d'entrada\n envien paquets a un \u00fanic enlla\u00e7 de sortida o si varien les velocitats de cada enlla\u00e7\n (FastEthernet a modem DSL).\n\n El servidor NDT genera i envia 10 segons de dades al client. En\n alguns casos el servidor pot generar les dades m\u00e9s de pressa del que pot enviar els paquets a la xarxa\n (p.ex., una CPU a 2 GHz enviant a un client conectat a una DSL).\n Quan passa aix\u00f2, alguns paquets es poden quedar a la cua de sortida /n quan s'acaba el temporitzador de 10 segons.\n El TCP continuar\u00e0 enviant automaticament aquests missatges a la cua i el client continuar\u00e0 acceptant-los i processant-los.\n Aix\u00f2 provoca que una prova duri m\u00e9s del que s'espera.\n\n Aquesta condici\u00f3 s'ha produït durant aquesta prova. /n No es requereix cap acci\u00f3 per a resoldre aquesta situaci\u00f3.
+packetSizePreserved = La mida del paquet \u00e9s prefixada Extrem-a-Extrem
+packetsize = la mida de paquet
+pc = PC
+pctOfTime = % del temps
+performedTests = Proves realitzades
+pktsRetrans = Paquets retransmesos
+possibleDuplexFullHalf = Alarma: Possible Condici\u00f3 doble no concordant detectada Switch=Full i Host=half
+possibleDuplexHalfFull = Alarma: Possible Condici\u00f3 doble no concordant detectada Switch=half i Host=full
+possibleDuplexHalfFullWarning = Advert\u00e8ncia: Possible Condici\u00f3 doble no concordant detectada Switch=half i Host=full
+preferIPv6 = prefereix IPv6
+printDetailedStats = Imprimir Estad\u00edstiques detallades
+protocolError = Error de Protocol! S'esperava 'prepare', s'obt\u00e9: 0x
+qSeen = Test de throughput: Detectat encuament de paquets
+ready = Tcpbw100 llest
+receiveBufferShouldBe = Informaci\u00f3: El buffer de recepci\u00f3 hauria de ser
+receiving = Rebent resultats...
+reportProblem = Informar el problema
+resultsParseError = Error en transformar els resultats del test!
+resultsTimeout = Alerta! Time-out al client mentre es llegien dades, (possible duplex mismatch exists)
+resultsWrongMessage = Resultats del test: S'ha rebut un tipus de missatge incorrecte
+rtt = RTT
+rttFail = L'algorisme del link de detecci\u00f3 ha fallat degut a excessius temps d'anada i tornada (Round trip times).
+runningInboundTest = executant test d'entrada de 10s (server-a-client [S2C]) . . . . . .
+runningOutboundTest = executant test de sortida de 10s (client-a-server [C2S]) . . . . .
+s2c = S2C
+s2cPacketQueuingDetected = [S2C]: Encuament de paquets detectat
+s2cThroughput = Throughput S2C
+s2cThroughputFailed = El test de throughput S2C ha FALLAT!
+sackReceived = Blocs SACK rebuts
+scalingFactors = Factors d'Escala
+seconds = segons
+server = Servidor
+serverAcksReport = El servidor confirma que l'enlla\u00e7 reportat \u00e9s
+serverFault = Fallida de Servidor: Error desconegut. Torneu-ho a provar m\u00e9s tard, si us plau.
+serverBusy = Servidor Ocupat: Massa clients esperant a la cua del servidor. Torneu-ho a provar m\u00e9s tard, si us plau.
+serverBusy15s = Servidor Ocupat: Esperi 15 segons per a la finalitzaci\u00f3 del test anterior.
+serverBusy30s = Servidor Ocupat: Esperi 30 segons per a la finalitzaci\u00f3 del test anterior.
+serverBusy60s = Servidor Ocupat: Esperi 60 segons per a la finalitzaci\u00f3 del test anterior.
+serverDataReports = Les dades del servidor indiquen que l'enlla\u00e7 \u00e9s
+serverFail = El servidor ha fallat mentre es rebien dades
+serverIpModified = Informaci\u00f3: El Network Address Translation (NAT) est\u00e0 modificant l'adre\u00e7a IP del client
+serverIpPreserved = L'adre\u00e7a IP del servidor es mant\u00e9 Extrem-a-Extrem
+serverNotRunning = Proc\u00e9s del servidor no funcionant: Arrenqui el proc\u00e9s web100srv al servidor remot.
+serverSays = El servidor diu
+sfwFail = Test de firewall simple FALLA!
+sfwSocketFail = Simple firewall test: Cannot create listen socket
+sfwTest = Simple firewall test...
+sfwWrongMessage = Test de firewall simple: S'ha rebut un missatge erroni.
+showOptions = Mostra les opcions
+simpleFirewall = Firewall simple
+sleep10m = Dormint per 10 mins...
+sleep1m = Dormint per 1 min...
+sleep30m = Dormint per 30 mins...
+sleep5m = Dormint per 5 mins...
+sleep12h = Dormint per 12 hores...
+sleep1d = Dormint per 1 d\u00eda...
+sleep2h = Dormint per 2 hores...
+start = COMEN\u00e7A
+startingTest = Comen\u00e7ant test
+statistics = Estad\u00edstiques
+stop = ATURA
+stopped = Les proves han estat aturades!
+stopping = Aturant...
+systemFault = Fallada de sistema
+test = Prova
+testsuiteWrongMessage = Negociant s\u00e8rie de proves: S'ha rebut un missatge erroni.
+theSlowestLink = El link m\u00e9s lent al cam\u00ed extrem a extrem \u00e9s un
+theoreticalLimit = El l\u00edmit te\u00f2ric de xarxa \u00e9s
+thisConnIs = Aquesta connexi\u00f3 \u00e9s
+timesPktLoss = temps degut a p\u00e8rdua de paquets
+toMaximizeThroughput = kbytes per a maximitzar el cabdal (throughput)
+troubleReportFrom = Informe de problemes de NDT a
+unableToDetectBottleneck = El servidor no pot determinar el tipus d'enlla\u00e7 que provoca el coll d'ampolla.
+unableToObtainIP = No es possible determinar la adre\u00e7a IP local
+unknownID = ID de test desconegut
+unknownServer = Servidor desconegut
+unsupportedClient = Informaci\u00f3: El servidor no suporta aquest client de l\u00ednia de comandes
+vendor = Fabricant
+version = Versi\u00f3
+versionWrongMessage = Negociant la versi\u00f3 de NDT: S'ha rebut un missatge erroni.
+web100Details = An\u00e0lisi detallat Web100
+web100KernelVar = Variables de Kernel WEB100
+web100Stats = Estad\u00edstiques WEB100 habilitades
+web100Var = Variables Web100
+web100rtt = Web100 informa el temps d'anada i tornada (RTT)
+web100tcpOpts = Web100 informa que TCP ha negociat els par\u00e0metres de funcionament \u00f2ptims a:
+willImprove = Millorar\u00e0 el funcionament
+workstation = Estaci\u00f3 de treball
+your = El seu
+yourPcHas = El seu PC/Equip de treball t\u00e9 un
+connectingTo = Connectant a
+toRunTest = executar prova
=======================================
--- /dev/null
+++ /branches/SamKnows/src/Tcpbw100_msgs_en_US.properties Tue Jun 1 09:44:58 2010
@@ -0,0 +1,219 @@
+10gbps = 10 Gbps 10 Gigabit Ethernet/OC-192 subnet
+10mbps = 10 Mbps Ethernet subnet
+10mins = 10 mins
+12hours = 12 hours
+1day = 1 day
+1gbps = 1.0 Gbps Gigabit Ethernet subnet
+1min = 1 min
+2.4gbps = 2.4 Gbps OC-48 subnet
+2hours = 2 hours
+30mins = 30 mins
+45mbps = 45 Mbps T3/DS3 subnet
+5mins = 5 mins
+622mbps = a 622 Mbps OC-12 subnet
+and = and
+architecture = Architecture
+bytes = Bytes
+c2s = C2S
+c2sPacketQueuingDetected = [C2S]: Packet queueing detected
+c2sThroughput = C2S throughput
+c2sThroughputFailed = C2S throughput test FAILED!
+cabledsl = Cable/DSL modem
+cablesNok = Warning: excessive network errors, check network cable(s)
+cablesOk = Good network cable(s) found
+checkingFirewalls = Checking for firewalls . . . . . . . . . . . . . . . . . . .
+checkingMiddleboxes = Checking for Middleboxes . . . . . . . . . . . . . . . . . .
+clickStart = Click START to start the test
+clickStart2 = Click START to re-test
+client = Client
+client2 = Client
+clientAcksReport = Client Acks report link is
+clientDataReports = Client Data reports link is
+clientInfo = Client System Details
+clientIpModified = Information: Network Address Translation (NAT) box is modifying the Client's IP address
+clientIpNotFound = Client IP address not found. For IE users, modify the Java parameters\n click Tools - Internet Options - Security - Custom Level, scroll down to\n Microsoft VM - Java permissions and click Custom, click Java Custom Settings\n Edit Permissions - Access to all Network Addresses, click Eanble and save changes
+clientIpPreserved = Server IP addresses are preserved End-to-End
+clientSays = but Client says
+close = Close
+comments = Comments
+congestNo = No network congestion discovered.
+congestYes = Information: throughput is limited by other network traffic.
+connIdle = The connection was idle
+connStalled = The connection stalled
+connected = Connected to:
+connectedTo = is connected to a
+copy = Copy
+defaultTests = Default tests
+delayBetweenTests = Delay between tests
+detailedStats = Detailed Statistics
+dialup = Dial-up Modem
+dialup2 = Dial-up
+done = Done.
+done2 = Tcpbw100 done
+dupAcksIn = duplicate acks received
+duplexFullHalf = Alarm: Duplex Mismatch condition detected Switch=Full and Host=half
+duplexHalfFull = Alarm: Duplex Mismatch condition detected Switch=half and Host=full
+duplexNok = Warning: Old Duplex mismatch condition detected:
+duplexOk = Normal duplex operation found.
+endOfEmail = End Of Email Message
+excLoss = Excessive packet loss is impacting your performance, check the auto-negotiate function on your local PC and network switch
+excessiveErrors = Alarm: Excessive errors, check network cable(s).
+firewallNo = is not behind a firewall. [Connection to the ephemeral port was successful]
+firewallYes = is probably behind a firewall. [Connection to the ephemeral port failed]
+flowControlLimits = The network based flow control limits the throughput to
+found100mbps = 100 Mbps FastEthernet link found.
+found10gbps = 10 Gbps 10 GigEthernet/OC-192 link found.
+found10mbps = 10 Mbps Ethernet link found.
+found1gbps = 1 Gbps GigabitEthernet link found.
+found2.4gbps = 2.4 Gbps OC-48 link found.
+found45mbps = 45 Mbps T3/DS3 link found.
+found622mbps = 622 Mbps OC-12 link found.
+foundDialup = Dial-up modem link found.
+foundDsl = Cable modem/DSL/T1 link found.
+fullDuplex = Full duplex Fast Ethernet subnet
+general = General
+generatingReport = Generating Trouble Report: This report will be emailed to the person you specify
+getWeb100Var = Get WEB100 Variables
+halfDuplex = Half duplex Fast Ethernet subnet
+id = TCP/Web100 Network Diagnostic Tool
+immediate = immediate
+inboundTest = Tcpbw100 inbound test...
+inboundWrongMessage = C2S throughput test: Received wrong type of the message
+incompatibleVersion = Incompatible version number
+incrRxBuf = Increasing the the client's receive buffer
+incrTxBuf = Increasing the NDT server's send buffer
+information = Information
+initialization = Initialization...
+insufficient = Insufficent data collected to determine link type.
+invokingMailtoFunction = Tcpbw100 Invoking Mailto function
+ipProtocol = IP protocol
+ipcFail = Interprocess communications failed, unknown link type.
+usingIpv4 = -- Using IPv4 address
+usingIpv6 = -- Using IPv6 address
+javaData = Java data
+kbyteBufferLimits = KByte buffer which limits the throughput to
+limitNet = network limited
+limitRx = receiver limited
+limitTx = sender limited
+linkFullDpx = Link set to Full Duplex mode
+linkHalfDpx = Link set to Half Duplex mode
+loggingWrongMessage = Logging to server: Received wrong type of the message
+lookupError = Unable to obtain remote IP address
+mboxWrongMessage = Middlebox test: Received wrong type of the message
+middlebox = Middlebox
+middleboxFail = Server Failed while middlebox testing
+middleboxFail2 = Middlebox test FAILED!
+middleboxModifyingMss = Information: Network Middlebox is modifying MSS variable
+middleboxTest = Tcpbw100 Middlebox test...
+moreDetails = More Details...
+name = Name
+ndtServerHas = The NDT server has a
+noPktLoss1 = No packet loss
+noPktLoss2 = No packet loss was observed
+numberOfTests = Number of tests
+of = of
+off = OFF
+ok = OK
+oldDuplexMismatch = "Warning: Old Duplex mismatch condition detected: "
+on = ON
+ooOrder = but packets arrived out-of-order
+options = Options
+osData = OS data:
+otherClient = Another client is currently being served, your test will begin within
+otherTraffic = Information: Other network traffic is congesting the link
+outboundTest = Tcpbw100 outbound test...
+outboundWrongMessage = C2S throughput test: Received wrong type of the message
+packetQueuing = Packet queuing
+packetQueuingInfo = TCP (Transmission Control Protocol) reliably transfers data between two\n Internet hosts. It automatically detects and recovers from errors and\n losses. TCP uses buffers to provide this reliability. In addition,\n switches and routers use buffers to handle cases where multiple input\n links send packets to a single output link or link speeds change\n (FastEthernet to DSL modem).\n\n The NDT server generates and sends 10 seconds of data to the client. In\n some cases the server can generate data faster than it can send packets\n into the network (e.g., a 2 GHz CPU sending to a DSL connected client).\n When this happens, some packets may remain in the server output queue\n when the 10 second timer expires. TCP will automatically continue to\n send these queued packets and the client will continue to accept and\n process these incoming packets. This will result in the client test\n running longer than expected.\n\n This condition has occurred during this test. No action is required to\n resolve this issue.
+packetSizePreserved = Packet size is preserved End-to-End
+packetsize = the Packet size
+pc = PC
+pctOfTime = % of the time
+performedTests = Performed tests
+pktsRetrans = packets retransmitted
+possibleDuplexFullHalf = Alarm: Possible Duplex Mismatch condition detected Switch=Full and Host=half
+possibleDuplexHalfFull = Alarm: Possible Duplex Mismatch condition detected Switch=half and Host=full
+possibleDuplexHalfFullWarning = Warning: Possible Duplex Mismatch condition detected Switch=half and Host=full
+preferIPv6 = prefer IPv6
+printDetailedStats = Print Detailed Statistics
+protocolError = Protocol error! Expected 'prepare', got: 0x
+qSeen = throughput test: Packet queuing detected
+ready = Tcpbw100 ready
+receiveBufferShouldBe = Information: The receive buffer should be
+receiving = Receiving results...
+reportProblem = Report problem
+resultsParseError = Error parsing test results!
+resultsTimeout = Warning! Client time-out while reading data, possible duplex mismatch exists
+resultsWrongMessage = Tests results: Received wrong type of the message
+rtt = RTT
+rttFail = Link detection algorithm failed due to excessive Round Trip Times.
+runningInboundTest = running 10s inbound test (server-to-client [S2C]) . . . . . .
+runningOutboundTest = running 10s outbound test (client-to-server [C2S]) . . . . .
+s2c = S2C
+s2cPacketQueuingDetected = [S2C]: Packet queueing detected
+s2cThroughput = S2C throughput
+s2cThroughputFailed = S2C throughput test FAILED!
+sackReceived = SACK blocks received
+scalingFactors = Scaling Factors
+seconds = seconds
+server = Server
+serverAcksReport = Server Acks report link is
+serverFault = Server Fault: unknown fault occurred. Please try again later
+serverBusy = Server Busy: Too many clients waiting in server queue. Please try again later
+serverBusy15s = Server Busy: Please wait 15 seconds for previous test to finish
+serverBusy30s = Server busy: Please wait 30 seconds for previous test to finish
+serverBusy60s = Server Busy: Please wait 60 seconds for previous test to finish
+serverDataReports = Server Data reports link is
+serverFail = Server failed while receiving data
+serverIpModified = Information: Network Address Translation (NAT) box is modifying the Client's IP address
+serverIpPreserved = Server IP addresses are preserved End-to-End
+serverNotRunning = Server process not running: start web100srv process on remote server
+serverSays = Server says
+sfwFail = Simple firewall test FAILED!
+sfwSocketFail = Simple firewall test: Cannot create listen socket
+sfwTest = Simple firewall test...
+sfwWrongMessage = Simple firewall test: Received wrong type of the message
+showOptions = Show options
+simpleFirewall = Simple firewall
+sleep10m = Sleeping for 10 mins...
+sleep1m = Sleeping for 1 min...
+sleep30m = Sleeping for 30 mins...
+sleep5m = Sleeping for 5 mins...
+sleep12h = Sleeping for 12 hours...
+sleep1d = Sleeping for 1 day...
+sleep2h = Sleeping for 2 hours...
+start = START
+startingTest = Starting test
+statistics = Statistics
+stop = STOP
+stopped = The tests were stopped!
+stopping = Stopping...
+systemFault = System Fault
+test = Test
+testsuiteWrongMessage = Negotiating test suite: Received wrong type of the message
+theSlowestLink = The slowest link in the end-to-end path is a
+theoreticalLimit = The theoretical network limit is
+thisConnIs = This connection is
+timesPktLoss = times due to packet loss
+toMaximizeThroughput = kbytes to maximize throughput
+troubleReportFrom = Trouble Report from NDT on
+unableToDetectBottleneck = Server unable to determine bottleneck link type.
+unableToObtainIP = Unable to obtain local IP address
+unknownID = Unknown test ID
+unknownServer = Unknown server
+unsupportedClient = Information: The server does not support this command line client
+vendor = Vendor
+version = Version
+versionWrongMessage = Negotiating NDT version: Received wrong type of the message
+web100Details = Web100 Detailed Analysis
+web100KernelVar = WEB100 Kernel Variables
+web100Stats = WEB100 Enabled Statistics
+web100Var = Web100 Variables
+web100rtt = Web100 reports the Round trip time
+web100tcpOpts = Web100 reports TCP negotiated the optional Performance Settings to:
+willImprove = will improve performance
+workstation = Workstation
+your = Your
+yourPcHas = Your PC/Workstation has a
+connectingTo = Connecting to
+toRunTest = to run test
=======================================
--- /dev/null
+++ /branches/SamKnows/src/Tcpbw100_msgs_fr_FR.properties Tue Jun 1 09:44:58 2010
@@ -0,0 +1,219 @@
+10gbps = sous-r\u00E9seau 10 Gbps 10 Gigabit Ethernet/OC-192
+10mbps = sous-r\u00E9seau 10 Mbps Ethernet
+10mins = 10 minutes
+12hours = 12 heures
+1day = 1 jour
+1gbps = sous-r\u00E9seau 1.0 Gbps Gigabit Ethernet
+1min = 1 minute
+2.4gbps = sous-r\u00E9seau 2.4 Gbps OC-48
+2hours = 2 heures
+30mins = 30 minutes
+45mbps = sous-r\u00E9seau 45 Mbps T3/DS3
+5mins = 5 minutes
+622mbps = sous-r\u00E9seau 622 Mbps OC-12
+and = et
+architecture = Architecture
+bytes = Bytes
+c2s = C2S
+c2sPacketQueuingDetected = [C2S]: D\u00E9tection de mise en file d'attente de paquets
+c2sThroughput = d\u00E9bit C2S
+c2sThroughputFailed = test de d\u00E9bit C2S \u00C9CHOU\u00C9!
+cabledsl = modem C\u00E2ble/DSL
+cablesNok = Attention: trop d'erreurs r\u00E9seau, v\u00E9rifiez le(s) c\u00E2ble(s) r\u00E9seau
+cablesOk = Bon(s) c\u00E2ble(s) r\u00E9seau trouv\u00E9s
+checkingFirewalls = V\u00E9rification de pr\u00E9sence de Firewalls . . . . . . . . . . . . . . . . . . .
+checkingMiddleboxes = V\u00E9rification de pr\u00E9sence de Middleboxes . . . . . . . . . . . . . . . . . .
+clickStart = Cliquez sur D\u00C9MARRER pour commencer le test
+clickStart2 = Cliquez sur D\u00C9MARRER pour re-tester
+client = Client
+client2 = Client
+clientAcksReport = Le lien des Acks clients est
+clientDataReports = Le lien des rapports de donn\u00E9es client est
+clientInfo = D\u00E9tails du syst\u00E8me client
+clientIpModified = Information: un \u00E9quipement Network Address Translation (NAT) modifie l'adresse IP du client
+clientIpNotFound = L'adresse IP du client non trouv\u00E9e. Pour les utilisateurs IE, modifiez les param\u00E8tres Java \n Cliquez sur Outils - Options Internet - S\u00E9curit\u00E9 - Niveau personnalis\u00E9, descendez jusqu'\u00E0\n Microsoft VM - permissions Java et cliquez sur Personnalis\u00E9, cliquez sur Param\u00E8tres Java personnalis\u00E9s\n \u00C9diter les permissions - Acc\u00E8s \u00E0 toutes les adresses r\u00E9seau, cliquez sur Appliquer et sauvegardez
+clientIpPreserved = Les adresses IP serveur sont pr\u00E9serv\u00E9es de bout en bout
+clientSays = mais le Client dit
+close = Fermez
+comments = Commentaires
+congestNo = Aucune congestion r\u00E9seau d\u00E9tect\u00E9e.
+congestYes = Information: le d\u00E9bit est limit\u00E9 par d'autres flux r\u00E9seau.
+connIdle = La connexion a \u00E9t\u00E9 oisive
+connStalled = La connexion a \u00E9t\u00E9 suspendue
+connected = Connect\u00E9 \u00E0:
+connectedTo = est connect\u00E9 \u00E0 un
+copy = Copiez
+defaultTests = Tests par d\u00E9faut
+delayBetweenTests = D\u00E9lai entre les tests
+detailedStats = Statistiques d\u00E9taill\u00E9es
+dialup = Dial-up Modem
+dialup2 = Dial-up
+done = R\u00E9alis\u00E9.
+done2 = Tcpbw100 r\u00E9alis\u00E9
+dupAcksIn = r\u00E9ception de acks en doublon
+duplexFullHalf = Alerte: condition de duplex mismatch d\u00E9tect\u00E9e, commutateur=full et h\u00F4te=half
+duplexHalfFull = Alerte: condition de duplex mismatch d\u00E9tect\u00E9e, commutateur=half et h\u00F4te=full
+duplexNok = Attention: condition de vieux duplex mismatch d\u00E9tect\u00E9e:
+duplexOk = Op\u00E9ration normale du duplex d\u00E9tect\u00E9e.
+endOfEmail = Fin de message e-mail
+excLoss = Une perte de paquets excessive diminue vos performances, v\u00E9rifiez les r\u00E9glages auto-negotiate de votre PC et du commutateur r\u00E9seau.
+excessiveErrors = Alerte: Trop d'erreurs, v\u00E9rifiez le(s) c\u00E2ble(s) r\u00E9seau.
+firewallNo = n'est pas derri\u00E8re un firewall. [Connexion vers un port \u00E9ph\u00E9m\u00E8re r\u00E9ussie]
+firewallYes = est probablement derri\u00E8re un firewall. [Connexion vers un port \u00E9ph\u00E9m\u00E8re \u00E9chou\u00E9e]
+flowControlLimits = Le contr\u00F4le de flux du r\u00E9seau limite le d\u00E9bit \u00E0
+found100mbps = Lien 100 Mbps FastEthernet d\u00E9tect\u00E9.
+found10gbps = Lien 10 Gbps 10 GigEthernet/OC-192 d\u00E9tect\u00E9.
+found10mbps = Lien 10 Mbps Ethernet d\u00E9tect\u00E9.
+found1gbps = Lien 1 Gbps GigabitEthernet d\u00E9tect\u00E9.
+found2.4gbps = Lien 2.4 Gbps OC-48 d\u00E9tect\u00E9.
+found45mbps = Lien 45 Mbps T3/DS3 d\u00E9tect\u00E9.
+found622mbps = Lien 622 Mbps OC-12 d\u00E9tect\u00E9.
+foundDialup = Lien modem Dial-up d\u00E9tect\u00E9.
+foundDsl = Lien C\u00E2ble modem/DSL/T1 d\u00E9tect\u00E9.
+fullDuplex = Full duplex Fast Ethernet subnet
+general = G\u00E9n\u00E9ral
+generatingReport = G\u00E9n\u00E9ration du rapport d'incident: Ce rapport sera envoy\u00E9 \u00E0 la personne sp\u00E9cifi\u00E9e
+getWeb100Var = R\u00E9cup\u00E9rer les variables WEB100
+halfDuplex = Half duplex Fast Ethernet subnet
+id = Outil de diagnostics r\u00E9seau TCP/Web100
+immediate = imm\u00E9diat
+inboundTest = test d'entr\u00E9e Tcpbw100...
+inboundWrongMessage = Test de d\u00E9bit C2S : r\u00E9ception du mauvais type de message
+incompatibleVersion = Num\u00E9ro de version incompatible
+incrRxBuf = Agrandissement du tampon de r\u00E9ception client
+incrTxBuf = Agrandissement du tampon d'\u00E9mission du serveur NDT
+information = Information
+initialization = Initialisation...
+insufficient = Trop peu de donn\u00E9es collect\u00E9es pour d\u00E9terminer le type de lien.
+invokingMailtoFunction = Tcpbw100 Appel de la fonction Mailto
+ipProtocol = Protocole IP
+ipcFail = Communication inter-processus \u00E9chou\u00E9e, type de lien inconnu.
+usingIpv4 = -- Utilisation de l'adresse IPv4
+usingIpv6 = -- Utilisation de l'adresse IPv6
+javaData = Donn\u00E9es Java
+kbyteBufferLimits = KByte tampon, ce qui limite le d\u00E9bit \u00E0
+limitNet = limit\u00E9 par le r\u00E9seau
+limitRx = limit\u00E9 par le r\u00E9cepteur
+limitTx = limit\u00E9 par l'\u00E9metteur
+linkFullDpx = Lien r\u00E9gl\u00E9 en mode Full Duplex
+linkHalfDpx = Lien r\u00E9gl\u00E9 en mode Half Duplex
+loggingWrongMessage = Enregistrement aupr\u00E8s du serveur: r\u00E9ception du mauvais type de message
+lookupError = Impossible d'obtenir l'adresse IP distante
+mboxWrongMessage = Test de middlebox : r\u00E9ception du mauvais type de message
+middlebox = Middlebox
+middleboxFail = \u00C9chec du serveur lors du test de middlebox
+middleboxFail2 = Test de middlebox \u00C9CHOU\u00C9!
+middleboxModifyingMss = Information: le Middlebox modifie la variable MSS
+middleboxTest = Tcpbw100 test de Middlebox...
+moreDetails = Plus de d\u00E9tails...
+name = Nom
+ndtServerHas = Le serveur NDT a un
+noPktLoss1 = Pas de perte de paquets
+noPktLoss2 = Aucune perte de paquets n'a \u00E9t\u00E9 observ\u00E9e
+numberOfTests = Nombre de tests
+of = de
+off = OFF
+ok = OK
+oldDuplexMismatch = "Attention: condition de vieux duplex mismatch d\u00E9tect\u00E9e: "
+on = ON
+ooOrder = mais les paquets sont arriv\u00E9s dans le d\u00E9sordre
+options = Options
+osData = Donn\u00E9es de l'OS:
+otherClient = Un autre client est actuellement en train d'\u00EAtre servi, votre test commencera dans
+otherTraffic = Information: d'autres flux r\u00E9seaux congestionnent le lien
+outboundTest = Tcpbw100 test de sortie ...
+outboundWrongMessage = Test de d\u00E9bit C2S : R\u00E9ception du mauvais type de message
+packetQueuing = Mise en file d'attente de paquets
+packetQueuingInfo = TCP (Transmission Control Protocol) transf\u00E8re des donn\u00E9es de mani\u00E8re fiable entre deux\n h\u00F4tes Internet. Il d\u00E9tecte et r\u00E9cup\u00E8re automatiquement les erreurs et\n pertes. TCP utilise des tampons pour fournir cette fiabilit\u00E9. De plus,\n des commutateurs et routeurs utilisent des tampons pour g\u00E9rer les cas dans lesquels plusieurs liens\n d'entr\u00E9e envoient des paquets \u00E0 un seul lien de sortie ou lorsque la vitesse des liens est diff\u00E9rente\n (FastEthernet vers un modem DSL).\n\n Le serveur NDT g\u00E9n\u00E8re et envoie 10 secondes de donn\u00E9es au client. Dans\n certains cas le serveur peut produire des donn\u00E9es plus vite qu'il ne peut envoyer les paquets\n vers le r\u00E9seau (p.e., un CPU de 2 GHz \u00E9mettant vers un client connect\u00E9 en DSL).\n Quand cela arrive, certains paquets peuvent rester dans la file d'attente de sortie du serveur\n lorsque la minuterie de 10 secondes se termine. TCP continuera automatiquement \n d'envoyer ces paquets en file d'attente et le client continuera \u00E0 les accepter et\n \u00E0 g\u00E9rer ces paquets entrants. Ceci aura pour r\u00E9sultat que le test client\n dure plus longtemps que pr\u00E9vu.\n\n Cette condition s'est r\u00E9alis\u00E9e durant ce test. Aucune action n'est n\u00E9cessaire pour r\u00E9soudre ce probl\u00E8me.
+packetSizePreserved = La taille des paquets est pr\u00E9serv\u00E9e de bout-en-bout
+packetsize = La taille des paquets
+pc = PC
+pctOfTime = % du temps
+performedTests = Tests r\u00E9alis\u00E9s
+pktsRetrans = paquets retransmis
+possibleDuplexFullHalf = Alerte: condition de duplex mismatch possible d\u00E9tect\u00E9e, commutateur=full et h\u00F4te=half
+possibleDuplexHalfFull = Alerte: condition de duplex mismatch possible d\u00E9tect\u00E9e, commutateur=half et h\u00F4te=full
+possibleDuplexHalfFullWarning = Attention: condition de duplex mismatch possible d\u00E9tect\u00E9e, commutateur=half et h\u00F4te=full
+preferIPv6 = pr\u00E9f\u00E9rer IPv6
+printDetailedStats = Afficher les statistiques d\u00E9taill\u00E9es
+protocolError = Erreur de protocole! Attendait 'prepare', re\u00E7u: 0x
+qSeen = test de d\u00E9bit: Mise en file d'attente de paquets d\u00E9tect\u00E9e
+ready = Tcpbw100 pr\u00EAt
+receiveBufferShouldBe = Information: Le tampon de r\u00E9ception devrait \u00EAtre
+receiving = Reception des r\u00E9sultats...
+reportProblem = Rapporter un probl\u00E8me
+resultsParseError = Erreur lors du traitement des r\u00E9sultats!
+resultsTimeout = Attention! D\u00E9passement du d\u00E9lai client lors de la lecture des donn\u00E9es, il y a peut-\u00EAtre un probl\u00E8me de duplex mismatch
+resultsWrongMessage = R\u00E9sultat des tests: r\u00E9ception du mauvais type de message
+rtt = RTT
+rttFail = L'algorithme de d\u00E9tection du lien a \u00E9chou\u00E9 \u00E0 cause d'un temps d'aller-retour (RTT) trop important.
+runningInboundTest = ex\u00E9cution du test d'entr\u00E9e de 10 secondes (server-to-client [S2C]) . . . . . .
+runningOutboundTest = ex\u00E9cution du test de sortie de 10s (client-to-server [C2S]) . . . . .
+s2c = S2C
+s2cPacketQueuingDetected = [S2C]: D\u00E9tection de mise en file d'attente de paquets
+s2cThroughput = d\u00E9bit S2C
+s2cThroughputFailed = Test de d\u00E9bit S2C \u00C9CHOU\u00C9!
+sackReceived = Blocs SACK re\u00E7us
+scalingFactors = Facteurs d'\u00E9chelle
+seconds = secondes
+server = Serveur
+serverAcksReport = les Acks du serveur rapportent que le lien est
+serverFault = Erreur du serveur: une erreur inconnue a eu lieu. Veuillez re-essayer plus tard.
+serverBusy = Serveur occup\u00E9: Trop de clients attendent dans la file d'attente du serveur. Veuillez re-essayer plus tard
+serverBusy15s = Serveur occup\u00E9: Veuillez attendre 15 secondes pour que le test pr\u00E9c\u00E9dant termine
+serverBusy30s = Serveur occup\u00E9: Veuillez attendre 30 secondes pour que le test pr\u00E9c\u00E9dant termine
+serverBusy60s = Serveur occup\u00E9: Veuillez attendre 60 secondes pour que le test pr\u00E9c\u00E9dant termine
+serverDataReports = Les donn\u00E9es du serveur rapportent que le lien est
+serverFail = Erreur du serveur lors de la r\u00E9ception des donn\u00E9es
+serverIpModified = Information: un \u00E9quipement Network Address Translation (NAT) modifie l'adresse IP du client
+serverIpPreserved = Les adresses IP du serveur sont conserv\u00E9es de bout en bout
+serverNotRunning = Processus serveur non actif: d\u00E9marrez le processus web100srv sur le serveur distant
+serverSays = Le serveur dit
+sfwFail = Le simple test firewall a \u00C9CHOU\u00C9!
+sfwSocketFail = Test simple du firewall: ne peut cr\u00E9er le socket d'\u00E9coute
+sfwTest = Test simple du firewall...
+sfwWrongMessage = Test simple du firewall : r\u00E9ception du mauvais type de message
+showOptions = Afficher les options
+simpleFirewall = Simple firewall
+sleep10m = En attente pour 10 minutes...
+sleep1m = En attente pour 1 minute...
+sleep30m = En attente pour 30 minutes...
+sleep5m = En attente pour 5 minutes...
+sleep12h = En attente pour 12 heures...
+sleep1d = En attente pour 1 jour...
+sleep2h = En attente pour 2 heures...
+start = D\u00C9MARRER
+startingTest = D\u00E9marrage du test
+statistics = Statistiques
+stop = ARRETER
+stopped = Les tests ont \u00E9t\u00E9 arr\u00EAt\u00E9s !
+stopping = Arr\u00EAt...
+systemFault = System Fault
+test = Test
+testsuiteWrongMessage = Negotiating test suite: r\u00E9ception du mauvais type de message
+theSlowestLink = Le lien le plus lent sur le chemin de bout en bout est un
+theoreticalLimit = La limite th\u00E9orique du r\u00E9seau est
+thisConnIs = Cette connexion est
+timesPktLoss = fois \u00E0 cause de la perte de paquets
+toMaximizeThroughput = kbytes pour maximiser le d\u00E9bit
+troubleReportFrom = Rapport d'incident de NDT sur
+unableToDetectBottleneck = Le serveur est incapable de d\u00E9terminer le type de lien du goulot d'\u00E9tranglement.
+unableToObtainIP = Impossible d'obtenir l'adresse IP locale
+unknownID = test ID inconnu
+unknownServer = Serveur inconnu
+unsupportedClient = Information: Le serveur n'accepte pas ce client en ligne de commande
+vendor = Vendeur
+version = Version
+versionWrongMessage = Negotiating NDT version: r\u00E9ception du mauvais type de message
+web100Details = Analyse d\u00E9taill\u00E9e Web100
+web100KernelVar = Variables du noyau WEB100
+web100Stats = Statistiques activ\u00E9es WEB100
+web100Var = Variables Web100
+web100rtt = Web100 rapporte le temps d'aller-retour (RTT)
+web100tcpOpts = Web100 rapporte que TCP a n\u00E9goci\u00E9 les param\u00E8tres de performances facultatifs \u00E0 :
+willImprove = am\u00E9liorera les performances
+workstation = Poste de travail
+your = Votre
+yourPcHas = Votre PC/Poste de travail a un
+connectingTo = Connexion \u00E0
+toRunTest = Pour d\u00E9marrer le test
=======================================
--- /dev/null
+++ /branches/SamKnows/src/Tcpbw100_msgs_nb_NO.properties Tue Jun 1 09:44:58 2010
@@ -0,0 +1,219 @@
+10gbps = 10 Gbps 10 Gigabit Ethernet/OC-192-subnett
+10mbps = 10 Mbps Ethernet-subnett
+10mins = 10 mins
+12hours = 12 hours
+1day = 1 d\u00f8ygn
+1gbps = 1.0 Gbps Gigabit Ethernet-subnett
+1min = 1 min
+2.4gbps = 2.4 Gbps OC-48-subnett
+2hours = 2 timer
+30mins = 30 min
+45mbps = 45 Mbps T3/DS3-subnett
+5mins = 5 min
+622mbps = et 622 Mbps OC-12-subnett
+and = og
+architecture = Arkitektur
+bytes = byte
+c2s = K-T
+c2sPacketQueuingDetected = [K-T]: Pakkek\u00f8ing oppdaget
+c2sThroughput = K-T ytelse
+c2sThroughputFailed = K-T ytelsestest FEILET!
+cabledsl = Kabel/DSL-modem
+cablesNok = Advarsel: for mange nettverksfeil, sjekk kablene.
+cablesOk = Nettverkskablene er i orden.
+checkingFirewalls = Ser etter brannmurer . . . . . . . . . . . . . . . . . . .
+checkingMiddleboxes = Ser etter mellombokser . . . . . . . . . . . . . . . . .
+clickStart = Trykk START for \u00e5 starte testene.
+clickStart2 = Trykk START for \u00e5 teste en gang til.
+client = Klient
+client2 = Klienten
+clientAcksReport = basert p\u00e5 ack fra klienten ansl\u00e5s linken til
+clientDataReports = Basert p\u00e5 data fra klienten ansl\u00e5s linken til
+clientInfo = Opplysninger om klientmaskinen
+clientIpModified = Til orientering: Network Address Translation (NAT) forandrer klientmaskinens IP-adresse
+clientIpNotFound = IP-addressen til klientmaskinen ble ikke funnet
+clientIpPreserved = Tjenermaskinens IP-adresse blir bevart fra ende til ende
+clientSays = men klienten sier
+close = Lukk
+comments = Kommentarer
+congestNo = Overbelastning i nettet ikke funnet.
+congestYes = Til orientering: ytelsen er begrenset av annen trafikk i nettet.
+connIdle = Forbindelsen ventet
+connStalled = Forbindelsen hang
+connected = Koblet til:
+connectedTo = er koblet til et
+connectingTo = Kobler opp mot
+copy = Kopier
+defaultTests = Standardtester
+delayBetweenTests = Delay between tests
+detailedStats = Detaljer
+dialup = Oppringt modem
+dialup2 = oppringt
+done = Ferdig
+done2 = Tcpbw100 ferdig
+dupAcksIn = dupliserte ack ble mottatt
+duplexFullHalf = Alarm: Dupleksitetsfeil oppdaget; svitsj=full og maskin=halv
+duplexHalfFull = Alarm: Dupleksitetsfeil oppdaget; svitsj=halv og maskin=full
+duplexNok = Alarm: Dupleksitetsfeil:
+duplexOk = Dupleksitet er i orden.
+endOfEmail = Slutt p\u00e5 epost
+excLoss = "H\u00f8yt pakketap begrenser ytelsen, kontroller automatisk konfigurering mellom din datamaskin og nettverkssvitsjen.
+excessiveErrors = Alarm: Alvorlige pakketap, sjekk nettverkskabler.
+firewallNo = er ikke bak brannmur. [Oppn\u00e5dde forbindelse med midlertidig port]
+firewallYes = er trolig bak en brannmur . [Oppn\u00e5dde ikke forbindelse med midlertidig port]
+flowControlLimits = Flytkontroll i nettet begrenser ytelsen til
+found100mbps = Link med 100 Mbit/s FastEthernet funnet.
+found10gbps = Link med 10 Gbit/s 10 GigEthernet/OC-192 funnet.
+found10mbps = Link med 10 Mbit/s Ethernet funnet.
+found1gbps = Link med 1 Gbit/s GigabitEthernet funnet.
+found2.4gbps = Link med 2.4 Gbit/s OC-48 funnet.
+found45mbps = Link med 45 Mbit/s T3/DS3 funnet.
+found622mbps = Link med 622 Mbit/s OC-12 funnet.
+foundDialup = Link med oppringt modem funnet.
+foundDsl = Link med kabelmodem/DSL/T1 funnet.
+fullDuplex = full dupleks "Fast Ethernet"-subnett
+general = Annet
+generatingReport = Genererer feilrapport; denne vil bli sendt til personen du spesifiserer
+getWeb100Var = Viser variabler fra WEB100
+halfDuplex = Halv-dupleks "Fast Ethernet"-subnett
+id = TCP/Web100 nettverksdiagnostikkverkt\u00f8y
+immediate = umiddelbart
+inboundTest = Tcpbw100 innkommende test...
+inboundWrongMessage = Klient-til-tjener-ytelsestest: mottok feil melding
+incompatibleVersion = Inkompatibelt versjonsnummer
+incrRxBuf = \u00c5 \u00f8ke klientmaskinens mottaksbuffer
+incrTxBuf = \u00c5 \u00f8ke tjenermaskinens sendebuffer
+information = Informasjon
+initialization = Initialiserer...
+insufficient = Ikke nok data til \u00e5 bestemme type link.
+invokingMailtoFunction = Tcpbw100 sender post
+ipProtocol = IP-protokoll
+ipcFail = Feil ved kommunikasjon mellom prosesser, type link ikke bestemt.
+javaData = Opplysninger om Java
+kbyteBufferLimits = kbyte som begrenser ytelsen til
+limitNet = begrenset av nettet
+limitRx = begrenset av mottakeren
+limitTx = begrenset av senderen
+linkFullDpx = Linken er i full dupleksmodus.
+linkHalfDpx = Linken er i halv dupleksmodus.
+loggingWrongMessage = Logging til tjener: Mottok feil type melding
+lookupError = Greide ikke sl\u00e5 opp tjenerens IP-addresse
+mboxWrongMessage = Mellombokstest: Mottok feil type melding
+middlebox = Mellomboks
+middleboxFail = Tjenerfeil under mellombokstesting
+middleboxFail2 = Mellombokstest feilet!
+middleboxModifyingMss = Til orientering: En mellomboks i nettet forandrer valgt MSS
+middleboxTest = Tcpbw100 mellombokstest...
+moreDetails = Detaljer
+name = Navn
+ndtServerHas = NDT-tjeneren har en buffer p\u00e5
+noPktLoss1 = Intet pakketap
+noPktLoss2 = Intet pakketap
+numberOfTests = Antall tester
+of = av
+off = AV
+ok = OK
+oldDuplexMismatch = Advarsel: Gammel dupleksitetsfeil oppdaget:
+on = P\u00C5
+ooOrder = men pakker ankom i feil rekkef\u00f8lge
+options = Innstillinger
+osData = Operativsystem:
+otherClient = Tjeneren er for \u00f8yeblikket opptatt med en annen klient. Testen din vil begynne innen
+otherTraffic = Informasjon: Annen trafikk overbelaster linken
+outboundTest = Tcpbw100 utg\u00e5ende test...
+outboundWrongMessage = K-T ytelsestest: mottok feil type melding
+packetQueuing = Pakkek\u00f8ing
+packetQueuingInfo = TCP (Transmission Control Protocol) er en p\u00e5litelig nettverksprotokoll\n som overf\u00f8rer data mellom forskjellige maskiner. Den oppdager og motvirker\n automatisk feil og pakketap. TCP bruker buffere for \u00e5 oppn\u00e5 dette.\n I tillegg s\u00e5 har svitsjer og rutere buffere for \u00e5 h\u00e5ndtere tilfeller\n hvor mange maskiner sender til samme port, eller hvor hastigheter\n endres (for eksempel "Fast Ethernet" eller et DSL-modem).\n \n NDT-tjeneren genererer og sender 10 sekunder med data til klienten.\n I noen tilfeller genererer tjeneren data kjappere enn den klarer \u00e5\n sende ut pakker til nettverket (for eksempel en tjener med 2GHz CPU\n som sender til en klient koblet til via DSL). N\u00e5r dette skjer, hender\n det at det er igjen pakker i pakkek\u00f8en n\u00e5r de 10 sekundene har passert.\n TCP vil automatisk fors\u00f8ke \u00e5 sende disse pakkene, selv om tiden er ute,\n og klienten vil fortsette \u00e5 motta de. Dette vil f\u00f8re til at klienttesten\n kan kj\u00f8re litt lenger enn forventet.\n \n Dette hendte under kj\u00f8ringen av denne testen. Du trenger ikke gj\u00f8re noe\n for \u00e5 fikse dette.
+packetSizePreserved = Pakkest\u00f8rrelse blir bevart fra ende til ende
+packetsize = pakkkest\u00f8rrelse
+pc = Personlig datamaskin
+pctOfTime = % av tiden
+performedTests = Tester \u00e5 utf\u00f8re
+pktsRetrans = pakker ble retransmittert
+possibleDuplexFullHalf = Alarm: Mulig dupleksitetsfeil oppdaget; svitsj=full og maskin=halv
+possibleDuplexHalfFull = Alarm: Mulig dupleksitetsfeil oppdaget; svitsj=halv og maskin=full
+possibleDuplexHalfFullWarning = Advarsel: Mulig dupleksitetsfeil oppdaget; svitsj=halv og maskin=full
+preferIPv6 = bruk IPv6 hvis mulig
+printDetailedStats = Viser detaljer
+protocolError = Protokollfeil! Mottok: 0x
+qSeen = ytelsestest: Pakkek\u00f8ing oppdaget
+ready = Tcpbw100 klar
+receiveBufferShouldBe = Informasjon: Mottaksbufferen burde v\u00e6re
+receiving = Henter resultater...
+reportProblem = Meld fra om problemer
+resultsParseError = Feil under tolkingen av testresultater!
+resultsTimeout = Advarsel! Tidsavbrudd under henting av data, mulig dupleksitetsfeil
+resultsWrongMessage = Testresultater: Mottok feil type melding
+rtt = rundreisetid
+rttFail = For lang rundreisetid til \u00e5 bestemme type link.
+runningInboundTest = Kj\u00f8rer 10 sekunders innkommende test (tjener-til-klient [T-K]) . . . .
+runningOutboundTest = Kj\u00f8rer 10 sekunders utg\u00e5ende test (klient-til-tjener [K-T]) . . . . . . .
+s2c = T-K
+s2cPacketQueuingDetected = [T-K]: Pakkek\u00f8ing oppdaget
+s2cThroughput = Ytelse tjener-klient
+s2cThroughputFailed = Ytelsestest fra tjener til klient FEILET!
+sackReceived = SACK-blokker ble mottatt.
+scalingFactors = Skaleringsfaktorer
+seconds = sekunder
+server = Tjener
+serverAcksReport = basert p\u00e5 ack fra tjeneren ansl\u00e5s linken til
+serverFault = Tjener Forkastningen; Ukjente forkastningen oppstod. Du kan pr\u00f8ve senere
+serverBusy = Tjener opptatt; For mange klienter i k\u00f8. Du kan pr\u00f8ve senere
+serverBusy15s = Tjener opptatt; vennligst vent 15 sekunder mens forrige test kj\u00f8res ferdig
+serverBusy30s = Tjener opptatt; vennligst vent 30 sekunder mens forrige test kj\u00f8res ferdig
+serverBusy60s = Tjener opptatt; vennligst vent 60 sekunder mens forrige test kj\u00f8res ferdig
+serverDataReports = Basert p\u00e5 data fra tjeneren ansl\u00e5s linken til
+serverFail = Tjenerfeil under mottak av data
+serverIpModified = Til orientering: Network Address Translation (NAT) forandrer klientmaskinens IP-adresse
+serverIpPreserved = Tjenermaskinens IP-adresse blir bevart fra ende til ende
+serverNotRunning = Tjenerprosess kj\u00f8rer ikke; vennligst start "web100srv" p\u00e5 tjeneren.
+serverSays = Tjeneren sier
+sfwFail = Enkel brannmurtest FEILET!
+sfwSocketFail = Enkel brannmurtest: Kan ikke opprette lytteport
+sfwTest = Enkel brannmurtest...
+sfwWrongMessage = Enkel brannmurtest: Mottok feil type melding
+showOptions = Vis innstillinger
+simpleFirewall = Enkel brannmur
+sleep10m = Venter 10 minutter...
+sleep12h = Venter 12 timer...
+sleep1d = Venter ett d\u00f8gn...
+sleep1m = Venter ett minutt...
+sleep2h = Venter to timer...
+sleep30m = Venter 30 minutter...
+sleep5m = Venter fem minutter...
+start = START
+startingTest = Starter test
+statistics = Statistikk
+stop = STOPP
+stopped = Testene ble stoppet!
+stopping = Stopper...
+systemFault = systemfeil
+test = Test
+testsuiteWrongMessage = Avtaler tester: Mottok feil type melding
+theSlowestLink = Den tregeste linken i stien mellom din maskin og tjeneren er et
+theoreticalLimit = Teoretisk grense for nettet er
+thisConnIs = Denne forbindelsen er
+timesPktLoss = ganger p\u00e5 grunn av pakketap
+toMaximizeThroughput = kilobyte for \u00e5 maksimere ytelsen
+toRunTest = for \u00e5 teste
+troubleReportFrom = Feilrapport fra NDT p\u00e5
+unableToDetectBottleneck = Tjeneren greide ikke \u00e5 bestemme flaskehalsen i stien
+unableToObtainIP = Kunne ikke f\u00e5 tak i den lokale IP-addressen
+unknownID = Ukjent test-ID
+unknownServer = Ukjent tjener
+unsupportedClient = Informasjon: Tjeneren st\u00f8tter ikke denne kommandolinjeklienten
+usingIpv4 = -- Bruker IPv4-addresse
+usingIpv6 = -- Bruker IPv6-addresse
+vendor = Leverand\u00f8r
+version = Versjon
+versionWrongMessage = Avtaler NDT-versjon: Mottok feil type melding
+web100Details = Detaljerte opplysninger fra Web100
+web100KernelVar = Kjernevariabler fra WEB100
+web100Stats = Statistikk fra WEB100
+web100Var = Variabler fra Web100
+web100rtt = Web100 melder at rundreisetid
+web100tcpOpts = Web100 melder at valgbare felt i TCP som p\u00e5virker ytelse er satt til:
+willImprove = vil forbedre ytelsen
+workstation = Arbeidsstasjon
+your = Din
+yourPcHas = Datamaskinen din har en buffer p\u00e5
=======================================
--- /dev/null
+++ /branches/SamKnows/src/Tcpbw100_msgs_nl_NL.properties Tue Jun 1 09:44:58 2010
@@ -0,0 +1,219 @@
+10gbps = 10 Gbps 10 Gigabit Ethernet/OC-192 subnet
+10mbps = 10 Mbps Ethernet subnet
+10mins = 10 minutes
+12hours = 12 uren
+1day = 1 dag
+1gbps = 1.0 Gbps Gigabit Ethernet subnet
+1min = 1 minuut
+2.4gbps = 2.4 Gbps OC-48 subnet
+2hours = 2 uren
+30mins = 30 minuten
+45mbps = 45 Mbps T3/DS3 subnet
+5mins = 5 minuten
+622mbps = a 622 Mbps OC-12 subnet
+and = en
+architecture = Architectuur
+bytes = Bytes
+c2s = C2S
+c2sPacketQueuingDetected = [C2S]: Packet queueing detected
+c2sThroughput = C2S doorvoer
+c2sThroughputFailed = C2S doorvoer test MISLUKT!
+cabledsl = Kabel/DSL modem
+cablesNok = Melding: erg veel netwerk errors, controleer de netwerk kabels
+cablesOk = Goede netwerk kabel(s) gevonden
+checkingFirewalls = Zoeken naar firewalls . . . . . . . . . . . . . . . . . . .
+checkingMiddleboxes = Zoeken naar tussenliggende routers . . . . . . . . . . . . . . . . . .
+clickStart = Klik START om de test te beginnen
+clickStart2 = Klik START om opnieuw te testen
+client = Client
+client2 = Client
+clientAcksReport = Client Acks zegt dat link is
+clientDataReports = Client Data zegt dat link is
+clientInfo = Client Systeem Details
+clientIpModified = Informatie: Network Address Translation (NAT) Uw router verandert het IP adres
+clientIpNotFound = Client IP adres niet gevonden. Voor IE gebruikers, verander de Java parameters\n Klik Tools - Internet Options - Security - Custom Level, scroll naar\n Microsoft VM - Java permissions en klik Custom, click Java Custom Settings\n Edit Permissions - Access to all Network Addresses, klik Enable en sla uw wijzigingen op
+clientIpPreserved = Server IP adressen zijn beveiligd End-to-End
+clientSays = maar Client zegt
+close = Sluiten
+comments = Commentaar
+congestNo = Geen netwerk overgebruik ontdekt.
+congestYes = Informatie: doorvoer is gelimiteerd door ander netwerk verkeer.
+connIdle = De connectie was idle
+connStalled = De connectie is vastgelopen
+connected = Verbonden met:
+connectedTo = is verbonden met een
+copy = Kopie
+defaultTests = Standaard tests
+delayBetweenTests = vertraging tussen tests
+detailedStats = Gedetailleerde Statistieken
+dialup = Inbel Modem
+dialup2 = Inbel
+done = Klaar.
+done2 = Tcpbw100 klaar
+dupAcksIn = meerdere dezelfde acks ontvangen
+duplexFullHalf = Alarm: Duplex Mismatch conditie gedetecteerd Switch=full en Host=half
+duplexHalfFull = Alarm: Duplex Mismatch conditie gedetecteerd Switch=half en Host=full
+duplexNok = Melding: Oude Duplex mismatch conditie gedetecteerd:
+duplexOk = Normale duplex instellingen gevonden.
+endOfEmail = Einde Van Email Bericht
+excLoss = Excessieve verloren pakketten zorgen voor een slechtere doorvoer, controleer de auto-negotiate functie op uw PC en de netwerk switch
+excessiveErrors = Alarm: Excessieve errors, controleer netwerk kabel(s).
+firewallNo = is niet achter een firewall. [Connectie naar de directe poort was succesvol]
+firewallYes = is waarschijnlijk achter een firewall. [Connectie naar de directe poort mislukt]
+flowControlLimits = Het network based flow control limiteerd de doorvoer tot
+found100mbps = 100 Mbps FastEthernet link gevonden.
+found10gbps = 10 Gbps 10 GigEthernet/OC-192 link gevonden.
+found10mbps = 10 Mbps Ethernet link gevonden.
+found1gbps = 1 Gbps GigabitEthernet link gevonden.
+found2.4gbps = 2.4 Gbps OC-48 link gevonden.
+found45mbps = 45 Mbps T3/DS3 link gevonden.
+found622mbps = 622 Mbps OC-12 link gevonden.
+foundDialup = Inbel modem link gevonden.
+foundDsl = Kabel modem/DSL/T1 link gevonden.
+fullDuplex = Full duplex Fast Ethernet subnet
+general = normaal
+generatingReport = Probleem Rapport Genereren: Dit rapport wordt gemaild naar de persoon die u opgeeft
+getWeb100Var = Vraag WEB100 Variabelen op
+halfDuplex = Half duplex Fast Ethernet subnet
+id = TCP/Web100 Network Diagnostic Tool
+immediate = direct
+inboundTest = Tcpbw100 inkomende test...
+inboundWrongMessage = C2S doorvoer test: Verkeerd type bericht ontvangen
+incompatibleVersion = Incompatibel versie nummer
+incrRxBuf = Verhogen van de client´s recieve buffer
+incrTxBuf = Verhogen van de server´s send buffer
+information = Informatie
+initialization = Initialisatie...
+insufficient = Niet genoeg data verzameld om link type te bepalen.
+invokingMailtoFunction = Tcpbw100 Mailto functie uitvoeren
+ipProtocol = IP protocol
+ipcFail = Inter-proces communicatie mislukt, onbekend link type.
+usingIpv4 = -- Maakt gebruik van IPv4 adres
+usingIpv6 = -- Maakt gebruik van IPv6 adres
+javaData = Java data
+kbyteBufferLimits = KByte buffer, dit limiteerd de doorvoer tot
+limitNet = netwerk gelimiteerd
+limitRx = ontvanger gelimiteerd
+limitTx = zender gelimiteerd
+linkFullDpx = Link aangepast naar Full Duplex mode
+linkHalfDpx = Link aangepast naar Half Duplex mode
+loggingWrongMessage = Loggen naar server: Verkeerd type bericht ontvangen
+lookupError = Kan geen remote IP adres verkrijgen
+mboxWrongMessage = Middlebox test: Verkeerd type bericht ontvangen
+middlebox = Middlebox
+middleboxFail = Server heeft gefaald while middlebox testing
+middleboxFail2 = Middlebox test MISLUKT!
+middleboxModifyingMss = Informatie: Netwerk Middlebox verandert MSS variabele
+middleboxTest = Tcpbw100 Middlebox test...
+moreDetails = Meer Details...
+name = Naam
+ndtServerHas = De NDT server heeft een
+noPktLoss1 = Geen verloren packets
+noPktLoss2 = Er zijn geen verloren packets geconstateerd
+numberOfTests = Aantal tests
+of = van
+off = OFF
+ok = OK
+oldDuplexMismatch = "Melding: Oude Duplex mismatch conditie gedetecteerd: "
+on = ON
+ooOrder = maar packets kwamen in de verkeerde volgorde aan
+options = Opties
+osData = OS data:
+otherClient = Op dit moment wordt een andere client geholpen, uw test begint zo spoedig mogelijk
+otherTraffic = Informatie: Ander netwerk verkeer vertraagd de connectie
+outboundTest = Tcpbw100 uitgaande test...
+outboundWrongMessage = C2S doorvoer test: Verkeerd type bericht ontvangen
+packetQueuing = Pakket queuing
+packetQueuingInfo = TCP (Transmission Control Protocol) verstuurd betrouwbaar tussen twee\n Internet hosts. Het detecteerd en hersteld error en verliezen.\n TCP gebruikt buffers om deze betrouwbaarheid te verzorgen. Daarnaast,\n hebben switches en routers ook buffers om situaties waarbij meerdere\n links pakketten versturen naar een enkele uitgaande poort of wanneer\n de link snelheid veranderd (FastEthernet naar DSL modem).\n\n De NDT server genereerd en verstuurd 10 seconden data naar de client. In\n sommige gevallen genereerd de server sneller pakketten dan er verstuurd\n kan worden naar het netwerk (bijv., een 2 GHz CPU naar een DSL link).\n Wanneer dit gebeurt, blijven sommige pakketten hangen in de server queue\n wanneer de 10 seconden timeout optreedt. TCP zal automatisch doorgaan\n met het verzenden van deze pakketten en de client zal deze ook blijven accepteren\n en behandelen. Dit kan ervoor zorgen dat de client test langer duurt dan gepland.\n\n Deze situatie heeft zich voorgedaan tijdens deze test. U hoeft geen actie te\n ondernemen om dit probleem op te lossen.\n
+packetSizePreserved = Pakket grootte is bewaard gebleven End-to-End
+packetsize = de Pakket grootte
+pc = PC
+pctOfTime = % van de tijd
+performedTests = Uitgevoerde tests
+pktsRetrans = pakketten opnieuw verstuurd
+possibleDuplexFullHalf = Alarm: Mogelijke Duplex Mismatch conditie gedetecteerd Switch=Full en Host=half
+possibleDuplexHalfFull = Alarm: Mogelijke Duplex Mismatch conditie gedetecteerd Switch=half en Host=full
+possibleDuplexHalfFullWarning = Warning: Alarm: Mogelijke Duplex Mismatch conditie gedetecteerd Switch=half en Host=full
+preferIPv6 = prefereer IPv6
+printDetailedStats = Print Gedetaileerde Statistieken
+protocolError = Protocol error! Verwachtte 'prepare', maar kreeg: 0x
+qSeen = doorvoer test: Pakket queuing gedetecteerd
+ready = Tcpbw100 klaar voor gebruik
+receiveBufferShouldBe = Informatie: The ontvangst buffer zou moeten zijn
+receiving = Resultaten ontvangen...
+reportProblem = Rapporteer een probleem
+resultsParseError = Error bij het parsen van de test resultaten!
+resultsTimeout = Melding! Client time-out tijden het lezen van de data, mogelijk duplex mismatch is aanwezig
+resultsWrongMessage = Test resultaten: Verkeerd type bricht ontvangen
+rtt = RTT
+rttFail = Link detectie algorithme mislukt vanwege excessieve Round Trip Times.
+runningInboundTest = uitvoeren 10s inkomende test (server-naar-client [S2C]) . . . . . .
+runningOutboundTest = uitvoeren 10s uitgaande test (client-naar-server [C2S]) . . . . .
+s2c = S2C
+s2cPacketQueuingDetected = [S2C]: Pakket queueing gedetecteerd
+s2cThroughput = S2C doorvoer
+s2cThroughputFailed = S2C tdoorvoer test MISLUKT!
+sackReceived = SACK blocks ontvangen
+scalingFactors = Scaling Factoren
+seconds = seconden
+server = Server
+serverAcksReport = Server Acks zegt dat link is
+serverFault = De Fout van de server: de onbekende fout kwam voor. Gelieve te proberen opnieuw later
+serverBusy = Server Bezig: Teveel clients wachtende in queue. Probeer het later nog eens
+serverBusy15s = Server Bezig: Wacht alstublieft 15 seconden om de vorige test af te ronden
+serverBusy30s = Server Bezig: Wacht alstublieft 30 seconden om de vorige test af te ronden
+serverBusy60s = Server Bezig: Wacht alstublieft 60 seconden om de vorige test af te ronden
+serverDataReports = Server Data zegt dat link is
+serverFail = Server fout tijdens het ontvangen van data
+serverIpModified = Informatie: Network Address Translation (NAT) box verandert het IP adres van de client
+serverIpPreserved = Server IP adressen worden behouden End-to-End
+serverNotRunning = Server proces draait niet: start het web100srv proces op de server
+serverSays = Server zegt
+sfwFail = Simpele firewall test MISLUKT!
+sfwSocketFail = Simpele firewall test: Kan geen listen socket aanmaken
+sfwTest = Simpele firewall test...
+sfwWrongMessage = Simpele firewall test: Verkeerd bericht ontvangen
+showOptions = Toon opties
+simpleFirewall = Simpele firewall
+sleep10m = Slapen voor 10 minuten...
+sleep1m = Slapen voor 1 minuut...
+sleep30m = Slapen voor 30 minuten...
+sleep5m = Slapen voor 5 minuten...
+sleep12h = Slapen voor 12 uren...
+sleep1d = Slapen voor 1 dag...
+sleep2h = Slapen voor 2 uren...
+start = START
+startingTest = Starten test
+statistics = Statistieken
+stop = STOP
+stopped = De tests zijn gestopt!
+stopping = Stoppen...
+systemFault = Systeem Fout
+test = Test
+testsuiteWrongMessage = Overleggen test suite: Verkeerd type bericht ontvangen
+theSlowestLink = De traagste link in het end-to-end pad is een
+theoreticalLimit = De theoretische netwerk limiet is
+thisConnIs = Deze connectie is
+timesPktLoss = keren vanwege packet loss
+toMaximizeThroughput = kbytes om doorvoer te maximaliseren
+troubleReportFrom = Probleem Rapport van NDT op
+unableToDetectBottleneck = Server kan de bottleneck link niet bepalen.
+unableToObtainIP = Kan lokaal IP adres niet achterhalen
+unknownID = Onbekend test ID
+unknownServer = Onbekende server
+unsupportedClient = Informatie: De server ondersteund deze command line client niet
+vendor = Bedrijf
+version = Versie
+versionWrongMessage = Overleggen NDT versie: Verkeerd type bericht ontvangen
+web100Details = Web100 gedetaileerde Analyze
+web100KernelVar = WEB100 Kernel Variabelen
+web100Stats = WEB100 Enabled Statistieken
+web100Var = Web100 Variabelen
+web100rtt = Web100 rapporteerd de Round trip time
+web100tcpOpts = Web100 heeft voor TCP de volgende optionele settings overlegd:
+willImprove = zal de performance verbeteren
+workstation = Werkstation
+your = Uw
+yourPcHas = Uw PC/Werkstation heeft een
+connectingTo = Connecten naar
+toRunTest = start test
=======================================
--- /dev/null
+++ /branches/SamKnows/src/Tcpbw100_msgs_pt_BR.properties Tue Jun 1 09:44:58 2010
@@ -0,0 +1,218 @@
+10gbps = sub-rede Gigabit Ethernet/OC-192 de 10 Gbps (10 Gbps 10 Gigabit Ethernet/OC-192 subnet)
+10mbps = sub-rede Ethernet de 10 Mbps (10 Mbps Ethernet subnet)
+10mins = 10 min
+12hours = 12 horas
+1day = 1 dia
+1gbps = sub-rede Gigabit Ethernet de 1.0 Gbps (1.0 Gbps Gigabit Ethernet subnet)
+1min = 1 min
+2.4gbps = sub-rede OC-48 de 2.4 Gbps ( 2.4 GbpsOC-48 subnet)
+2hours = 2 horas
+30mins = 30 min
+45mbps = sub-rede T3/DS3 de 45 Mbps (45 Mbps T3/DS3 subnet)
+5mins = 5 min
+622mbps = uma sub-rede OC-12 de 622 Mbps ( a 622 Mbps OC-12 subnet)
+and = e
+architecture = Arquitetura
+bytes = Bytes
+c2s = C2S
+c2sPacketQueuingDetected = [C2S]: Fila de pacotes detectada
+c2sThroughput = C2S taxa de transfer\u00EAncia
+c2sThroughputFailed = C2S teste de taxa de transfer\u00EAncia FALHOU!
+cabledsl = Cabo/ modem DSL
+cablesNok = Aviso: excessivos erros de rede detectados, verifique o(s) cabo(s) de rede
+cablesOk = Encontrado(s) cabo(s) de rede adequados
+checkingFirewalls = Procurando por firewalls . . . . . . . . . . . . . . . . . . .
+checkingMiddleboxes = Procurando por Middleboxes . . . . . . . . . . . . . . . . . .
+clickStart = Clique em INICIAR para iniciar o teste
+clickStart2 = Clique em INICIAR para executar o teste novamente
+client = Cliente
+client2 = Cliente
+clientAcksReport = Cliente Acks reporta que o link \u00E9
+clientDataReports = Dados do Cliente reporta que o link \u00E9
+clientInfo = Detalhes do Sistema do Cliente
+clientIpModified = Informa\u00E7\u00E3o: Network Address Translation (NAT) box est\u00E1 modificando o endere\u00E7o IP do cliente
+clientIpNotFound = Endere\u00E7o IP do Cliente n\u00E3o encontrado. Para usu\u00E1rios do IE, altere os par\u00E2metros do Java\n clique em Ferramentas - Op\u00E7\u00F5es da Internet - Seguran\u00E7a - N\u00EDvel personalizado, role para baixo at\u00E9 Microsoft VM - Permiss\u00F5es Java e clique em Customizar, clique Customizar configura\u00E7\u00F5es do Java\n Edite as Permiss\u00F5es - Acesse todos Endere\u00E7os de Rede, clique em habilitar e salve as altera\u00E7\u00F5es
+clientIpPreserved = Endere\u00E7os IP do Servidor s\u00E3o preservados fim a fim
+clientSays = mas o Cliente diz
+close = Fechar
+comments = Comment\u00E1rios
+congestNo = Congestionamento da rede n\u00E3o foi detectado
+congestYes = Informa\u00E7\u00E3o: taxa de transfer\u00EAncia \u00E9 limitada devido a outro tr\u00E1fego de rede.
+connIdle = A conex\u00E3o estava ociosa em
+connStalled = A conex\u00E3o foi interrompida
+connected = Conectado a:
+connectedTo = est\u00E1 conectado a um(a)
+copy = Copiar
+defaultTests = Testes padr\u00E3o
+delayBetweenTests = Atraso entre os testes
+detailedStats = Estat\u00EDsticas detalhadas
+dialup = Modem Dial-up
+dialup2 = Discada
+done = Conclu\u00EDdo
+done2 = Tcpbw100 conclu\u00EDdo.
+dupAcksIn = acks duplicados recebidos
+duplexFullHalf = Alerta: Dupla condi\u00E7\u00E3o de incompatibilidade detectada Switch=Full e Host=half
+duplexHalfFull = Alerta: Dupla condi\u00E7\u00E3o de incompatibilidade detectada Switch=half e Host=full
+duplexNok = Aviso: Antiga dupla condi\u00E7\u00E3o de incompatibilidade detectada:
+duplexOk = Dupla opera\u00E7\u00E3o normal encontrada.
+endOfEmail = Final da mensagem de E-mail
+excLoss = Excessiva perda de pacotes est\u00E1 impactando na sua performance, cheque a fun\u00E7\u00E3o auto-negotiate no seu computador local e no switch da rede
+excessiveErrors = Alerta: Erros excessivos, verifique o(s) cabo(s) de rede.
+firewallNo = n\u00E3o protegido por firewall. [Conex\u00E3o com a porta ef\u00EAmera conclu\u00EDda com \u00EAxito]
+firewallYes = provavelmente protegido por firewall. [Conex\u00E3o com a porta ef\u00EAmera falhou]
+flowControlLimits = O controle de fluxo da rede limita a taxa de transfer\u00EAncia em
+found100mbps = link de 100 Mbps FastEthernet encontrado.
+found10gbps = link de 10 Gbps 10 GigEthernet/OC-192 encontrado.
+found10mbps = link de 10 Mbps Ethernet encontrado.
+found1gbps = link de 1 Gbps GigabitEthernet encontrado.
+found2.4gbps = link de 2.4 Gbps OC-48 encontrado.
+found45mbps = link de 45 Mbps T3/DS3 encontrado.
+found622mbps = link de 622 Mbps OC-12 encontrado.
+foundDialup = link de Dial-up modem encontrado.
+foundDsl = link de modem a cabo/DSL/T1 encontrado.
+fullDuplex = sub-rede Full duplex Fast Ethernet
+general = Geral
+generatingReport = Gerando Relat\u00F3rio de Problemas: Esse relat\u00F3rio ser\u00E1 enviado por email para a pessoa que voc\u00EA especificar
+getWeb100Var = Buscar vari\u00E1veis web100
+halfDuplex = sub-rede Half duplex Fast Ethernet
+id = TCP/Web100 Ferramenta de Diagn\u00F3stico da Rede
+immediate = imediato
+inboundTest = Tcpbw100 teste de entrada inbound test...
+inboundWrongMessage = C2S teste de taxa de transfer\u00EAncia: Tipo errado de mensagem foi recebido
+incompatibleVersion = N\u00FAmero da vers\u00E3o incompat\u00EDvel
+incrRxBuf = Aumentando o buffer de recep\u00E7\u00E3o do cliente
+incrTxBuf = Aumentando o buffer de envio do servidor NDT
+information = Informa\u00E7\u00E3o
+initialization = Inicializa\u00E7\u00E3o...
+insufficient = Dados coletados s\u00E3o insuficientes para determinar tipo de link.
+invokingMailtoFunction = Tcpbw100 Chamando fun\u00E7\u00E3o Mailto
+ipProtocol = Protocolo IP
+ipcFail = Comunica\u00E7\u00F5es entre processos falhou, tipo de link desconhecido.
+usingIpv4 = -- Usando endere\u00E7o IPv4
+usingIpv6 = -- Usando endere\u00E7o IPv6
+javaData = Dados Java
+kbyteBufferLimits = KByte buffer que limita a taxa de transfer\u00EAncia para
+limitNet = limitada pela rede em
+limitRx = destinat\u00E1rio limitado
+limitTx = remetende limitado
+linkFullDpx = Link definido/configurado para modo Full Duplex
+linkHalfDpx = Link definido/configurado para modo Half Duplex
+loggingWrongMessage = Logando ao servidor: Tipo errado de mensagem foi recebido
+lookupError = N\u00E3o foi poss\u00EDvel obter o endere\u00E7o IP remoto
+mboxWrongMessage = Teste Middlebox : Tipo errado de mensagem foi recebido
+middlebox = Middlebox
+middleboxFail = Servidor falhou durante o teste de middlebox
+middleboxFail2 = Teste Middlebox FALHOU!
+middleboxModifyingMss = Informa\u00E7\u00E3o: Middlebox da Rede est\u00E1 modificando a vari\u00E1vel MSS
+middleboxTest = Tcpbw100 teste Middlebox ...
+moreDetails = Mais Detalhes...
+name = Nome
+ndtServerHas = O servidor NDT possui um
+noPktLoss1 = Perda de pacotes n\u00E3o
+noPktLoss2 = N\u00E3o foi observada perda de pacotes
+numberOfTests = N\u00FAmero de testes
+of = de
+off = DESLIGADO
+ok = OK
+oldDuplexMismatch = "Aviso: Antiga dupla condi\u00E7\u00E3o de incompatibilidade detectada:"
+on = LIGADO
+ooOrder = mas os pacotes fotam recebidos fora da ordem
+options = Op\u00E7\u00F5es
+osData = Dados do SO:
+otherClient = Outro cliente est\u00E1 sendo servido, seu teste ter\u00E1 in\u00EDcio em
+otherTraffic = Informa\u00E7\u00E3o: Tr\u00E1fego de outras redes est\u00E1 congestionando o link
+outboundTest = Tcpbw100 teste de sa\u00EDda...
+outboundWrongMessage = C2S teste de taxa de transfer\u00EAncia: Tipo errado de mensagem foi recebido
+packetQueuing = Filas de Pacotes
+packetQueuingInfo = TCP (Protocolo de Controle de Transmiss\u00E3o) transfere dados de forma confi\u00E1vel entre dois\n hosts. Ele automaticamente detecta e recupera de erros\ n e perdas. O TCP usa buffers para prover essa confiabilidade. Al\u00E9m disso, switches e roteadores usam buffers para lidar/gerenciar casos em que v\u00E1rios links enviam pacotes para uma \u00FAnica sa\u00EDda ou a velocuidade do link muda\n (Ethernet R\u00E1pida para modem DSL.\n\n O servidor NDT gera e envia 10 segundos de dados para o cliente. Em\n alguns casos o servidor pode gerar dados mais r\u00E1pido do que enviar pacotes para a rede (ex: um CPU de 2GHz enviando para um cliente conectado a um DSL).\n Quando isso ocorre, alguns pacotes podem ficar enfileiirados na sa\u00EDda do servidor\n quando \u00E9 expirado o tempo de 10 segundos. O TCP automaticamente continuar\u00E1 a enviar esses pacotes enfileirados e o cliente vai continuar aceitando e processando esses pacotes. Isso resulta em um maior tempo de execu\u00E7\u00E3o do teste do cliente. Essa situa\u00E7\u00E3o ocorreu durante esse teste. Nenhuma a\u00E7\u00E3o \u00E9 requerida para\n resolver esse problema.
+packetSizePreserved = O Tamanho do Pacote \u00E9 preservado Fim a Fim
+packetsize = o tamanho do Pacote
+pc = PC
+pctOfTime = % do tempo
+performedTests = Testes executados
+pktsRetrans = pacotes retransmitidos
+possibleDuplexFullHalf = Alarme: Poss\u00EDvel Dupla condi\u00E7\u00E3o de incompatibilidade detectada Switch=Full e Host=half
+possibleDuplexHalfFull = Alarme: Poss\u00EDvel Dupla condi\u00E7\u00E3o de incompatibilidade detectada Switch=half e Host=full
+possibleDuplexHalfFullWarning = Aviso: Poss\u00EDvel Dupla condi\u00E7\u00E3o de incompatibilidade detectada Switch=half e Host=full
+preferIPv6 = prefira IPv6
+printDetailedStats = Imprima as Estat\u00EDsticas Detalhadas
+protocolError = Erro de Protocolo! Esperado 'prepare', obtido: 0x
+qSeen = teste de taxa de transfer\u00EAncia: Enfileiramento de pacotes detectado
+ready = Tcpbw100 pronto
+receiveBufferShouldBe = Informa\u00E7\u00E3o: O buffer de recep\u00E7\u00E3o deve ser
+receiving = Recebendo resultados...
+reportProblem = Reportar problema
+resultsParseError = Erro ao analisar os resultados do teste!
+resultsTimeout = Aviso! Tempo do cliente expirou ao ler os dados, poss\u00EDvel exist\u00EAncia de uma dupla condi\u00E7\u00E3o de incompatibilidade
+resultsWrongMessage = Resultados dos Testes: Tipos errados de mensagem foram recebidos
+rtt = RTT
+rttFail = Algor\u00EDtmo de detec\u00E7\u00E3o do link falhou devido a excessivos
+runningInboundTest = executando teste de entrada de 10s (servidor para cliente [S2C]) . . . . . .
+runningOutboundTest = executando teste de sa\u00EDda de 10s (cliente para servidor [C2S]) . . . . .
+s2c = S2C
+s2cPacketQueuingDetected = [S2C]: Enfileiramento de pacotes detectados
+s2cThroughput = S2C taxa de transfer\u00EAncia
+s2cThroughputFailed = S2C teste de taxa de transfer\u00EAncia FALHOU!
+sackReceived = Blocos SACK recebidos
+scalingFactors = Fatores de Escala/escalonamento
+seconds = segundos
+server = Servidor
+serverAcksReport = Servidor Acks reporta que o link \u00E9
+serverBusy = Servidor Ocupado: Muitos clientes aguardando na fila do servidor. Por favor, tente novamente mais tarde.
+serverBusy15s = Servidor Ocupado: Por favor, aguarde 15 segundos para a finaliza\u00E7\u00E3o do teste anterior
+serverBusy30s = Servidor Ocupado: Por favor, aguarde 30 segundos para a finaliza\u00E7\u00E3o do teste anterior
+serverBusy60s = Servidor Ocupado: Por favor, aguarde 60 segundos para a finaliza\u00E7\u00E3o do teste anterior
+serverDataReports = Dados do servidor reporta que o link \u00E9
+serverFail = Servidor falhou enquanto recebia dados
+serverIpModified = Informa\u00E7\u00E3o: Network Address Translation (NAT) box est\u00E1 modificando o endere\u00E7o IP do cliente
+serverIpPreserved = Endere\u00E7os IP do Servidor s\u00E3o preservados fim a fim
+serverNotRunning = Processo do servidor n\u00E3o est\u00E1 executando : inicie o processo web100srv no servidor remoto
+serverSays = Servidor diz
+sfwFail = Teste simples de firewall FALHOU!
+sfwSocketFail = Teste simples de firewall: N\u00E3o pode ser criado socket para escuta
+sfwTest = Teste simples de firewall...
+sfwWrongMessage = Teste simples de firewall: Tipos errados de mensagem foram recebidos
+showOptions = Mostrar op\u00E7\u00F5es
+simpleFirewall = Firewall simples
+sleep10m = Dormindo por 10 min...
+sleep1m = Dormindo por 1 min...
+sleep30m = Dormindo por 30 min...
+sleep5m = Dormindo por 5 min...
+sleep12h = Dormindo por 12 horas...
+sleep1d = Dormindo por 1 dia...
+sleep2h = Dormindo por 2 horas...
+start = INICIAR
+startingTest = Iniciando Teste
+statistics = Estat\u00EDsticas
+stop = PARAR
+stopped = Os testes foram interrompidos!
+stopping = Parando...
+systemFault = Falha do Sistema
+test = Teste
+testsuiteWrongMessage = Negotiating test suite: Tipos errados de mensagem foram recebidos
+theSlowestLink = O link mais lento no caminho fim a fim \u00E9
+theoreticalLimit = O limite te\u00F3rico da rede \u00E9
+thisConnIs = A conex\u00E3o est\u00E1
+timesPktLoss = vezes devido a perda de pacotes
+toMaximizeThroughput = kbytes para maximizar a taxa de transfer\u00EAncia
+troubleReportFrom = Trouble Report from NDT on
+unableToDetectBottleneck = Servidor n\u00E3o conseguiu determinar o tipo de gargalo.
+unableToObtainIP = N\u00E3o foi poss\u00EDvel obter o endere\u00E7o IP local
+unknownID = ID de teste desconhecido
+unknownServer = Servidor desconhecido
+unsupportedClient = Informa\u00E7\u00E3o: Esse servidor n\u00E3o fornece suporte a essa linha de comando
+vendor = Fabricante
+version = Vers\u00E3o
+versionWrongMessage = Negociando vers\u00E3o do NDT : Tipo errado de mensagem foi recebido
+web100Details = An\u00E1lise detalhada WEB100
+web100KernelVar = Vari\u00E1veis do Kernel WEB100
+web100Stats = Estat\u00EDsticas WEB100 dispon\u00EDveis
+web100Var = Vari\u00E1veis Web100
+web100rtt = Web100 reporta o tempo de Ida e Volta
+web100tcpOpts = Web100 verifica que TCP negociou as configura\u00E7\u00F5es de performance opicionais para:
+willImprove = ir\u00E1 melhorar a performance
+workstation = Esta\u00E7\u00E3o de trabalho
+your = Sua
+yourPcHas = Seu PC/Esta\u00E7\u00E3o de Trabalho tem um
+connectingTo = Conectando a
+toRunTest = para executar o teste
=======================================
--- /dev/null
+++ /branches/SamKnows/src/Tcpbw100_msgs_ru_RU.properties Tue Jun 1 09:44:58 2010
@@ -0,0 +1,217 @@
+10gbps = 10 \u0413\u0431\u0438\u0442/\u0441\u0435\u043A 10 Gigabit Ethernet/OC-192 \u043F\u043E\u0434\u0441\u0435\u0442\u044C
+10mbps = 10 \u041C\u0431\u0438\u0442/\u0441\u0435\u043A Ethernet \u043F\u043E\u0434\u0441\u0435\u0442\u044C
+10mins = 10 \u043C\u0438\u043D\u0443\u0442
+12hours = 12 \u0447\u0430\u0441\u043E\u0432
+1day = 1 \u0434\u0435\u043D\u044C
+1gbps = 1 \u0413\u0431\u0438\u0442/\u0441 Gigabit Ethernet \u043F\u043E\u0434\u0441\u0435\u0442\u044C
+1min = 1 \u043C\u0438\u043D
+2.4gbps = 2,4 \u0413\u0431\u0438\u0442/\u0441 OC-48 \u043F\u043E\u0434\u0441\u0435\u0442\u044C
+2hours = 2 \u0447\u0430\u0441\u0430
+30mins = 30 \u043C\u0438\u043D\u0443\u0442
+45mbps = 45 \u041C\u0431\u0438\u0442/\u0441 T3/DS3 \u043F\u043E\u0434\u0441\u0435\u0442\u044C
+5mins = 5 \u043C\u0438\u043D\u0443\u0442
+622mbps = 622 \u041C\u0431\u0438\u0442/\u0441 OC-12 \u043F\u043E\u0434\u0441\u0435\u0442\u044C
+and = \u0438
+architecture = \u0410\u0440\u0445\u0438\u0442\u0435\u043A\u0442\u0443\u0440\u0430
+bytes = \u0431\u0430\u0439\u0442
+c2s = C2S
+c2sPacketQueuingDetected = [C2S]: \u041E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E \u043D\u0430\u043A\u043E\u043F\u043B\u0435\u043D\u0438\u0435 \u043F\u0430\u043A\u0435\u0442\u043E\u0432 \u0432 \u043E\u0447\u0435\u0440\u0435\u0434\u0438
+c2sThroughput = C2S \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043Da\u044F \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u044C
+c2sThroughputFailed = C2S \u0442\u0435\u0441\u0442 \u043D\u0430 \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043D\u0443\u044E \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u044C \u043D\u0435 \u0441\u0440\u0430\u0431\u043E\u0442\u0430\u043B !
+cabledsl = \u043A\u0430\u0431\u0435\u043B\u044C\u043D\u044B\u0439 \u043C\u043E\u0434\u0435\u043C
+cablesNok = \u041F\u0440\u0435\u0434\u0443\u043F\u0440\u0435\u0436\u0434\u0435\u043D\u0438\u0435: \u0447\u0440\u0435\u0437\u043C\u0435\u0440\u043D\u043E\u0435 \u043A\u043E\u043B\u0438\u0447\u0435\u0441\u0442\u0432\u043E \u043E\u0448\u0438\u0431\u043E\u043A \u0441\u0435\u0442\u0438, \u043F\u0440\u043E\u0432\u0435\u0440\u044C\u0442\u0435 \u0441\u0435\u0442\u0435\u0432\u043E\u0439 \u043A\u0430\u0431\u0435\u043B\u044C
+cablesOk = \u0421\u0435\u0442\u0435\u0432\u043E\u0439 \u043A\u0430\u0431\u0435\u043B\u044C \u0432 \u043F\u043E\u0440\u044F\u0434\u043A\u0435
+checkingFirewalls = \u041F\u0440\u043E\u0432\u0435\u0440\u043A\u0430 \u0441\u0435\u0442\u0435\u0432\u044B\u0445 \u044D\u043A\u0440\u0430\u043D\u043E\u0432. . . . . . . . . . . . . . . . . . .
+checkingMiddleboxes = \u041F\u0440\u043E\u0432\u0435\u0440\u043A\u0430 \u041F\u0440\u043E\u043C\u0435\u0436\u0443\u0442\u043E\u0447\u043D\u044B\u0445 \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432 \u0441\u0435\u0442\u0438. . . . . . . . . . . . . . . . . .
+clickStart = \u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0421\u0422\u0410\u0420\u0422, \u0447\u0442\u043E\u0431\u044B \u043D\u0430\u0447\u0430\u0442\u044C \u0442\u0435\u0441\u0442
+clickStart2 = \u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0421\u0422\u0410\u0420\u0422, \u0447\u0442\u043E\u0431\u044B \u043F\u043E\u0432\u0442\u043E\u0440\u0438\u0442\u044C \u0442\u0435\u0441\u0442\u0438\u0440\u043E\u0432\u0430\u043D\u0438\u0435
+client = \u041A\u043B\u0438\u0435\u043D\u0442
+client2 = \u041A\u043B\u0438\u0435\u043D\u0442
+clientAcksReport = \u041A\u043B\u0438\u0435\u043D\u0442 \u043F\u043E\u0434\u0442\u0432\u0435\u0440\u0434\u0438\u043B \u0441 Ack \u0447\u0442\u043E \u043B\u0438\u043D\u043A
+clientDataReports = \u0414\u0430\u043D\u043D\u044B\u0435 \u043A\u043B\u0438\u0435\u043D\u0442\u0430 \u043F\u043E\u0434\u0442\u0432\u0435\u0440\u0436\u0434\u0430\u044E\u0442 \u0447\u0442\u043E
+clientInfo = \u0414\u0430\u043D\u043D\u044B\u0435 \u043E \u043A\u043B\u0438\u0435\u043D\u0442\u0435
+clientIpModified = \u0418\u043D\u0444\u043E\u0440\u043C\u0430\u0446\u0438\u044F: \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E \u043F\u0440\u0435\u043E\u0431\u0440\u0430\u0437\u043E\u0432\u0430\u043D\u0438\u044F \u0441\u0435\u0442\u0435\u0432\u044B\u0445 \u0430\u0434\u0440\u0435\u0441\u043E\u0432 (NAT) \u0438\u0437\u043C\u0435\u043D\u044F\u0435\u0442 IP-\u0430\u0434\u0440\u0435\u0441 \u043A\u043B\u0438\u0435\u043D\u0442\u0430
+clientIpNotFound = IP-\u0430\u0434\u0440\u0435\u0441 \u041A\u043B\u0438\u0435\u043D\u0442\u0430 \u043D\u0435 \u043D\u0430\u0439\u0434\u0435\u043D. \u0414\u043B\u044F IE \u043F\u043E\u043B\u044C\u0437\u043E\u0432\u0430\u0442\u0435\u043B\u0435\u0439, \u043F\u043E\u043F\u0440\u043E\u0431\u0443\u0439\u0442\u0435 \u0438\u0437\u043C\u0435\u043D\u0438\u0442\u044C \u043F\u0430\u0440\u0430\u043C\u0435\u0442\u0440\u044B Java \n \u0432\u044B\u0431\u0435\u0440\u0438\u0442\u0435 \u0432 \u043C\u0435\u043D\u044E Service \u2013 Network Options - Security - Level, \u043F\u0440\u043E\u043B\u0438\u0441\u0442\u043D\u0438\u0442\u0435 \u0432\u043D\u0438\u0437 \u0434\u043E \n Microsoft VM - Java Permissions \u0438 \u043D\u0430\u0436\u043C\u0438\u0442\u0435 \u043A\u043D\u043E\u043F\u043A\u0443 Custom, \u0449\u0435\u043B\u043A\u043D\u0438\u0442\u0435 na Java Custom Settings \n Edit Persmissions - \u0434\u043E\u0441\u0442\u0443\u043F \u043A\u043E \u0432\u0441\u0435\u043C \u0441\u0435\u0442\u0435\u0432\u044B\u043C \u0430\u0434\u0440\u0435\u0441\u0430\u043C, \u043D\u0430\u0436\u043C\u0438\u0442\u0435 \u043A\u043D\u043E\u043F\u043A\u0443 En\u0430ble \u0438 \u0441\u043E\u0445\u0440\u0430\u043D\u0438\u0442e \u0438\u0437\u043C\u0435\u043D\u0435\u043D\u0438\u044F
+clientIpPreserved = IP \u0430\u0434\u0440\u0435\u0441\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u0431\u044B\u043B\u0438 \u0441\u043E\u0445\u0440\u0430\u043D\u0435\u043D\u044B \u0431\u0435\u0437 \u0438\u0437\u043C\u0435\u043D\u0430\u043D\u0438\u044F \u043D\u0430 \u0432\u0441\u0435\u043C \u043F\u0443\u0442\u0438
+clientSays =, \u043D\u043E \u043A\u043B\u0438\u0435\u043D\u0442 \u0441\u043E\u043E\u0431\u0449\u0430\u0435\u0442
+close = \u0417\u0430\u043A\u0440\u044B\u0442\u044C
+comments = \u041A\u043E\u043C\u043C\u0435\u043D\u0442\u0430\u0440\u0438\u0438
+congestNo = \u041F\u0435\u0440\u0435\u0433\u0440\u0443\u0436\u0435\u043D\u043D\u043E\u0441\u0442\u044C \u0441\u0435\u0442\u0438 \u043D\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u0430.
+congestYes = \u0418\u043D\u0444\u043E\u0440\u043C\u0430\u0446\u0438\u044F: \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043D\u0430\u044F \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u044C \u043E\u0433\u0440\u0430\u043D\u0438\u0447\u0435\u043D\u0430 \u043F\u043E\u0441\u0442\u043E\u0440\u043E\u043D\u043D\u0438\u043C \u0441\u0435\u0442\u0435\u0432\u044B\u043C \u0442\u0440\u0430\u0444\u0438\u043A\u043E\u043C.
+connIdle = \u0421\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u043F\u0440\u043E\u0445\u043B\u0430\u0436\u0434\u0430\u043B\u043E\u0441\u044C \u0431\u0435\u0437 \u0442\u0440\u0430\u0444\u0438\u043A\u0430
+connStalled = \u0421\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u0437\u0430\u0441\u0442\u0440\u044F\u043B\u043E
+connected = \u041F\u043E\u0434\u043A\u043B\u044E\u0447\u0435\u043D\u043E \u043A:
+connectedTo = \u043F\u043E\u0434\u043A\u043B\u044E\u0447\u0435\u043D \u043A
+copy = \u041A\u043E\u043F\u0438\u0440\u043E\u0432\u0430\u0442\u044C
+defaultTests = \u0422\u0435\u0441\u0442\u044B \u0443\u0441\u0442\u0430\u043D\u043E\u0432\u043B\u0435\u043D\u043D\u044B\u0435 \u043F\u043E \u0443\u043C\u043E\u043B\u0447\u0430\u043D\u0438\u044E
+delayBetweenTests = \u0417\u0430\u0434\u0435\u0440\u0436\u043A\u0430 \u043C\u0435\u0436\u0434\u0443 \u0442\u0435\u0441\u0442\u0430\u043C\u0438
+detailedStats = \u041F\u043E\u0434\u0440\u043E\u0431\u043D\u0430\u044F \u0421\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043A\u0430
+dialup = \u043C\u043E\u0434\u0435\u043C
+dialup2 = \u043C\u043E\u0434\u0435\u043C
+done = \u0413\u043E\u0442\u043E\u0432\u043E
+done2 = Tcpbw100 \u0433\u043E\u0442\u043E\u0432\u043E
+dupAcksIn = \u043F\u043E\u043B\u0443\u0447\u0435\u043D\u044B \u0434\u0443\u0431\u043B\u0438\u0440\u043E\u0432\u0430\u043D\u043D\u044B\u0435 acks
+duplexFullHalf = \u0412\u043D\u0438\u043C\u0430\u043D\u0438\u0435: \u041E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E \u041D\u0435\u0441\u043E\u0432\u043F\u0430\u0434\u0435\u043D\u0438\u0435 \u0434\u0443\u043F\u043B\u0435\u043A\u0441\u0430 Switch=\u0434\u0443\u043F\u043B\u0435\u043A\u0441 \u0438 Host=\u043F\u043E\u043B\u0443\u0434\u0443\u043F\u043B\u0435\u043A\u0441
+duplexHalfFull = \u0412\u043D\u0438\u043C\u0430\u043D\u0438\u0435: \u041E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E \u041D\u0435\u0441\u043E\u0432\u043F\u0430\u0434\u0435\u043D\u0438\u0435 \u0434\u0443\u043F\u043B\u0435\u043A\u0441\u0430 Switch=\u043F\u043E\u043B\u0443\u0434\u0443\u043F\u043B\u0435\u043A\u0441 \u0438 Host=\u0434\u0443\u043F\u043B\u0435\u043A\u0441
+duplexNok = \u041F\u0440\u0435\u0434\u0443\u043F\u0440\u0435\u0436\u0434\u0435\u043D\u0438\u0435: \u0440\u0430\u043D\u0435\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043D\u043E\u0435 \u041D\u0435\u0441\u043E\u0432\u043F\u0430\u0434\u0435\u043D\u0438\u0435 \u0434\u0443\u043F\u043B\u0435\u043A\u0441\u0430 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E:
+duplexOk = \u041D\u043E\u0440\u043C\u0430\u043B\u044C\u043D\u044B\u0439 \u0440\u0435\u0436\u0438\u043C \u0440\u0430\u0431\u043E\u0442\u044B \u0434\u0443\u043F\u043B\u0435\u043A\u0441\u0430 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D.
+endOfEmail = \u041E\u043A\u043E\u043D\u0447\u0430\u043D\u0438\u0435 \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0433\u043E \u0441\u043E\u043E\u0431\u0449\u0435\u043D\u0438\u044F
+excLoss = \u0427\u0440\u0435\u0437\u043C\u0435\u0440\u043D\u044B\u0435 \u043F\u043E\u0442\u0435\u0440\u0438 \u0441\u0435\u0442\u0435\u0432\u044B\u0445 \u043F\u0430\u043A\u0435\u0442\u043E\u0432 \u0441\u043A\u0430\u0437\u044B\u0432\u0430\u0435\u0442\u0441\u044F \u043D\u0430 \u0440\u0430\u0431\u043E\u0442\u0435 \u0432\u0430\u0448\u0435\u0439 \u0441\u0435\u0442\u0438, \u043F\u0440\u043E\u0432\u0435\u0440\u044C\u0442\u0435 \u0444\u0443\u043D\u043A\u0446\u0438\u044E \u0430\u0432\u0442\u043E-\u0441\u043E\u0433\u043B\u0430\u0441\u043E\u0432\u0430\u043D\u0438\u044F \u0434\u0443\u043F\u043B\u0435\u043A\u0441\u0430 \u043D\u0430 \u0432\u0430\u0448\u0435\u043C \u041F\u041A \u0438 \u043D\u0430 \u0431\u043B\u0438\u0436\u0430\u0439\u0448\u0435\u043C \u0441\u0435\u0442\u0435\u0432\u043E\u043C \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u0435
+excessiveErrors = \u0412\u043D\u0438\u043C\u0430\u043D\u0438\u0435: \u0447\u0440\u0435\u0437\u043C\u0435\u0440\u043D\u043E\u0435 \u043A\u043E\u043B\u0438\u0447\u0435\u0441\u0442\u0432\u043E \u043E\u0448\u0438\u0431\u043E\u043A, \u043F\u0440\u043E\u0432\u0435\u0440\u044C\u0442\u0435 \u0441\u0435\u0442\u0435\u0432\u043E\u0439 \u043A\u0430\u0431\u0435\u043B\u044C(\u044B).
+firewallNo = \u043D\u0435 \u043D\u0430\u0445\u043E\u0434\u0438\u0442\u0441\u044F \u0437\u0430 \u043C\u0435\u0436\u0441\u0435\u0442\u0435\u0432\u044B\u043C \u044D\u043A\u0440\u0430\u043D\u043E\u043C. [\u041F\u043E\u0434\u043A\u043B\u044E\u0447\u0435\u043D\u0438\u0435 \u043A \u0432\u0438\u0440\u0442\u0443\u0430\u043B\u044C\u043D\u043E\u043C\u0443 \u043F\u043E\u0440\u0442 \u043F\u0440\u043E\u0448\u043B\u043E \u0443\u0441\u043F\u0435\u0448\u043D\u043E]
+firewallYes = \u0432\u0435\u0440\u043E\u044F\u0442\u043D\u043E \u0437\u0430 \u043C\u0435\u0436\u0441\u0435\u0442\u0435\u0432\u044B\u043C \u044D\u043A\u0440\u0430\u043D\u043E\u043C. [\u041D\u0435 \u0443\u0434\u0430\u043B\u043E\u0441\u044C \u043F\u043E\u0434\u043A\u043B\u044E\u0447\u0438\u0442\u044C\u0441\u044F \u043A \u0432\u0438\u0440\u0442\u0443\u0430\u043B\u044C\u043D\u043E\u043C\u0443 \u043F\u043E\u0440\u0442\u0443]
+flowControlLimits = \u041D\u0430\u0441\u0442\u0440\u043E\u0439\u043A\u0438 \u0443\u043F\u0440\u0430\u0432\u043B\u0435\u043D\u0438\u044F \u0441\u0435\u0442\u0435\u0432\u044B\u043C \u043F\u043E\u0442\u043E\u043A\u043E\u043C \u043E\u0433\u0440\u0430\u043D\u0438\u0447\u0438\u0432\u0430\u0435\u0442 \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043D\u0443\u044E \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u044C
+found100mbps = 100 \u041C\u0431\u0438\u0442/\u0441 FastEthernet \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E.
+found10gbps = 10 \u0413\u0431\u0438\u0442/\u0441 10 GigEthernet/OC-192 \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E.
+found10mbps = 10 \u041C\u0431\u0438\u0442/\u0441 Ethernet \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E.
+found1gbps = 1 \u0413\u0431\u0438\u0442/\u0441 GigabitEthernet \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E.
+found2.4gbps = 2,4 \u0413\u0431\u0438\u0442/\u0441 OC-48 \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E.
+found45mbps = 45 \u041C\u0431\u0438\u0442/\u0441 T3/DS3 \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E.
+found622mbps = 622 \u041C\u0431\u0438\u0442/\u0441 OC-12 \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E.
+foundDialup = \u041C\u043E\u0434\u0435\u043C\u043D\u043E\u0435 \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E.
+foundDsl = \u041A\u0430\u0431\u0435\u043B\u044C\u043D\u043E\u0435 modem/DSL/T1 \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E.
+fullDuplex = \u043F\u043E\u043B\u043D\u043E\u0434\u0443\u043F\u043B\u0435\u043A\u0441\u043D\u0430\u044F Fast Ethernet \u043F\u043E\u0434\u0441\u0435\u0442\u044C
+general= \u041E\u0431\u0449\u0438\u0435
+generatingReport = \u0413\u043E\u0442\u043E\u0432\u0438\u0442\u0441\u044F \u043E\u0442\u0447\u0435\u0442 \u043E \u043F\u0440\u043E\u0431\u043B\u0435\u043C\u0435: \u0414\u0430\u043D\u043D\u044B\u0439 \u043E\u0442\u0447\u0435\u0442 \u0431\u0443\u0434\u0435\u0442 \u0432\u044B\u0441\u043B\u0430\u043D \u0443\u043A\u0430\u0437\u0430\u043D\u043D\u044B\u043C \u043B\u0438\u0446\u0430\u043C
+getWeb100Var = \u041F\u043E\u043B\u0443\u0447\u0438\u0442\u044C WEB100 \u043F\u0435\u0440\u0435\u043C\u0435\u043D\u043D\u044B\u0435
+halfDuplex = \u043F\u043E\u043B\u0443\u0434\u0443\u043F\u043B\u0435\u043A\u0441\u043D\u0430\u044F Fast Ethernet \u043F\u043E\u0434\u0441\u0435\u0442\u044C ID = TCP/Web100 Network Diagnostic Tool (NDT)
+immediate = \u0441\u0438\u044E \u043C\u0438\u043D\u0443\u0442\u0443
+inboundTest = Tcpbw100 \u0432\u0445\u043E\u0434\u044F\u0449\u0438\u0439 \u0442\u0435\u0441\u0442 ...
+inboundWrongMessage = C2S \u0442\u0435\u0441\u0442 \u043D\u0430 \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043D\u0443\u044E \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u044C:\u041F\u043E\u043B\u0443\u0447\u0435\u043D \u043D\u0435\u043F\u0440\u0430\u0432\u0438\u043B\u044C\u043D\u044B\u0439 \u0442\u0438\u043F \u0441\u043E\u043E\u0431\u0449\u0435\u043D\u0438\u044F
+incompatibleVersion = \u041D\u0435\u0441\u043E\u0432\u043C\u0435\u0441\u0442\u0438\u043C\u0430\u044F \u0432\u0435\u0440\u0441\u0438\u044F
+incrRxBuf = \u0423\u0432\u0435\u043B\u0438\u0447\u0435\u043D\u0438\u0435 \u043F\u0440\u0438\u0435\u043C\u043D\u043E\u0433\u043E \u0431\u0443\u0444\u0435\u0440\u0430 \u043A\u043B\u0438\u0435\u043D\u0442\u0430
+incrTxBuf = \u0423\u0432\u0435\u043B\u0438\u0447\u0435\u043D\u0438\u0435 \u0431\u0443\u0444\u0435\u0440\u0430 \u043E\u0442\u043F\u0440\u0430\u0432\u043A\u0438 \u043D\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0435 NDT
+information = \u0418\u043D\u0444\u043E\u0440\u043C\u0430\u0446\u0438\u044F
+initialization = \u0418\u043D\u0438\u0446\u0438\u0430\u043B\u0438\u0437\u0430\u0446\u0438\u044F ...
+insufficient = \u041D\u0435\u0434\u043E\u0441\u0442\u0430\u0442\u043E\u0447\u043D\u043E \u0434\u0430\u043D\u043D\u044B\u0445, \u0441\u043E\u0431\u0440\u0430\u043D\u043D\u044B\u0445 \u0434\u043B\u044F \u043E\u043F\u0440\u0435\u0434\u0435\u043B\u0435\u043D\u0438\u044F \u0442\u0438\u043F\u0430 \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u044F.
+invokingMailtoFunction = Tcpbw100 \u0412\u044B\u0437\u043E\u0432 \u0444\u0443\u043D\u043A\u0446\u0438\u0438 Mailto
+ipProtocol = \u0418\u043D\u0442\u0435\u0440\u043D\u0435\u0442 \u043F\u0440\u043E\u0442\u043E\u043A\u043E\u043B
+ipcFail = \u041C\u0435\u0436\u043F\u0440\u043E\u0446\u0435\u0441\u0441\u043D\u043E\u0435 \u0441\u043E\u043E\u0431\u0449\u0435\u043D\u0438\u0435 \u0431\u044B\u043B\u043E \u043D\u0430\u0440\u0443\u0448\u0435\u043D\u043E, \u0442\u0438\u043F \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u044F \u043D\u0435 \u043E\u043F\u0440\u0435\u0434\u0435\u043B\u0435\u043D.
+usingIpv4 = -- \u0418\u0441\u043F\u043E\u043B\u044C\u0437\u0443\u044E IPv4 \u0430\u0434\u0440\u0435\u0441
+usingIpv6 = -- \u0418\u0441\u043F\u043E\u043B\u044C\u0437\u0443\u044E IPv6 \u0430\u0434\u0440\u0435\u0441
+javaData = Java \u043D\u0430\u0441\u0442\u0440\u043E\u0439\u043A\u0438
+kbyteBufferLimits = \u041A\u0411\u0430\u0439\u0442 \u0440\u0430\u0437\u043C\u0435\u0440 \u0431\u0443\u0444\u0435\u0440\u0430, \u043A\u043E\u0442\u043E\u0440\u044B\u0439 \u043E\u0433\u0440\u0430\u043D\u0438\u0447\u0438\u0432\u0430\u0435\u0442 \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043D\u0443\u044E \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u044C
+limitNet = \u0441\u0435\u0442\u044C \u043E\u0433\u0440\u0430\u043D\u0438\u0447\u0435\u043D\u0430
+limitRx = \u043F\u0440\u0438\u0435\u043C\u043D\u0438\u043A \u043E\u0433\u0440\u0430\u043D\u0438\u0447\u0435\u043D
+limitTx = \u043E\u0442\u043F\u0440\u0430\u0432\u0438\u0442\u0435\u043B\u044C \u043E\u0433\u0440\u0430\u043D\u0438\u0447\u0435\u043D
+linkFullDpx = \u0421\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u0443\u0441\u0442\u0430\u043D\u043E\u0432\u043B\u0435\u043D\u043E \u0432 \u043F\u043E\u043B\u043D\u044B\u0439 \u0434\u0443\u043F\u043B\u0435\u043A\u0441\u043D\u044B\u0439 \u0440\u0435\u0436\u0438\u043C
+linkHalfDpx =\u0421\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435 \u0443\u0441\u0442\u0430\u043D\u043E\u0432\u043B\u0435\u043D\u043E \u0432 \u043F\u043E\u043B\u0443\u0434\u0443\u043F\u043B\u0435\u043A\u0441\u043D\u043E\u043C \u0440\u0435\u0436\u0438\u043C\u0435
+loggingWrongMessage = \u0421\u043E\u043E\u0431\u0449\u0435\u043D\u0438\u0435 \u043D\u0430 \u0441\u0435\u0440\u0432\u0435\u0440: \u041F\u043E\u043B\u0443\u0447\u0435\u043D \u043D\u0435\u043F\u0440\u0430\u0432\u0438\u043B\u044C\u043D\u044B\u0439 \u0442\u0438\u043F \u0441\u043E\u043E\u0431\u0449\u0435\u043D\u0438\u044F
+lookupError = \u041D\u0435\u0432\u043E\u0437\u043C\u043E\u0436\u043D\u043E \u043E\u043F\u0440\u0435\u0434\u0435\u043B\u0438\u0442\u044C \u0443\u0434\u0430\u043B\u0435\u043D\u043D\u044B\u0439 IP-\u0430\u0434\u0440\u0435\u0441
+mboxWrongMessage = \u0422\u0435\u0441\u0442 \u043F\u0440\u043E\u043C\u0435\u0436\u0443\u0442\u043E\u0447\u043D\u044B\u0445 \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432: \u041F\u043E\u043B\u0443\u0447\u0435\u043D \u043D\u0435\u043F\u0440\u0430\u0432\u0438\u043B\u044C\u043D\u044B\u0439 \u0442\u0438\u043F \u0441\u043E\u043E\u0431\u0449\u0435\u043D\u0438\u044F
+middlebox = \u041F\u0440\u043E\u043C\u0435\u0436\u0443\u0442\u043E\u0447\u043D\u043E\u0435 \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E
+middleboxFail = \u0418\u0421\u0414 \u043D\u0435 \u0441\u043C\u043E\u0433 \u043F\u0440\u043E\u0442\u0435\u0441\u0442\u0438\u0440\u043E\u0432\u0430\u0442\u044C \u043F\u0440\u043E\u043C\u0435\u0436\u0443\u0442\u043E\u0447\u043D\u043E\u0435 \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E
+middleboxFail2 = \u0422\u0435\u0441\u0442\u0438\u0440\u043E\u0432\u0430\u043D\u0438\u0435 \u043F\u0440\u043E\u043C\u0435\u0436\u0443\u0442\u043E\u0447\u043D\u044B\u0445 \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432 \u0431\u044B\u043B\u043E \u043E\u0431\u043E\u0440\u0432\u0430\u043D\u043E !
+middleboxModifyingMss = \u0418\u043D\u0444\u043E\u0440\u043C\u0430\u0446\u0438\u044F: \u041F\u0440\u043E\u043C\u0435\u0436\u0443\u0442\u043E\u0447\u043D\u043E\u0435 \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E \u0441\u0435\u0442\u0438 \u0438\u0437\u043C\u0435\u043D\u044F\u0435\u0442 MSS(\u041C\u0430\u043A\u0441\u0438\u043C\u0430\u043B\u044C\u043D\u044B\u0439 \u0440\u0430\u0437\u043C\u0435\u0440 \u0441\u0435\u0433\u043C\u0435\u043D\u0442\u0430 \u0434\u0430\u043D\u043D\u044B\u0445)
+middleboxTest = Tcpbw100 \u0442\u0435\u0441\u0442\u0438\u0440\u0443\u0435\u0442 \u043F\u0440\u043E\u043C\u0435\u0436\u0443\u0442\u043E\u0447\u043D\u043E\u0435 \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E \u0441\u0435\u0442\u0438...
+moreDetails = \u041F\u043E\u0434\u0440\u043E\u0431\u043D\u0435\u0435 ...
+name = \u0438\u043C\u044F
+ndtServerHas = NDT \u0441\u0435\u0440\u0432\u0435\u0440
+noPktLoss1 = \u041F\u043E\u0442\u0435\u0440\u044C \u043F\u0430\u043A\u0435\u0442\u043E\u0432 \u043D\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E
+noPktLoss2 = \u041F\u043E\u0442\u0435\u0440\u044C \u043F\u0430\u043A\u0435\u0442\u043E\u0432 \u043D\u0435 \u043D\u0430\u0431\u043B\u044E\u0434\u0430\u043B\u043E\u0441\u044C
+numberOfTests = \u0447\u0438\u0441\u043B\u043E \u0442\u0435\u0441\u0442\u043E\u0432
+of =
+off = \u0412\u044B\u043A\u043B
+ok = \u0412\u0432\u0435\u0441\u0442\u0438
+oldDuplexMismatch = \u201C\u041F\u0440\u0435\u0434\u0443\u043F\u0440\u0435\u0436\u0434\u0435\u043D\u0438\u0435: \u0420\u0430\u043D\u0435\u0435 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043D\u043E\u0435 \u043D\u0435\u0441\u043E\u0432\u043F\u0430\u0434\u0435\u043D\u0438\u0435 \u0434\u0443\u043F\u043B\u0435\u043A\u0441\u0430 \u0441\u043D\u043E\u0432\u0430 \u0431\u044B\u043B\u043E \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E:"
+on = \u0412\u043A\u043B
+ooOrder = \u043D\u043E \u043F\u0430\u043A\u0435\u0442\u044B \u043F\u0440\u0438\u0431\u044B\u043B\u0438 \u0432\u043D\u0435 \u043F\u043E\u0440\u044F\u0434\u043A\u0430
+options = \u041D\u0430\u0441\u0442\u0440\u043E\u0439\u043A\u0438 \u041F\u0430\u0440\u0430\u043C\u0435\u0442\u0440\u043E\u0432
+osData = \u0414\u0430\u043D\u043D\u044B\u0435 \u041E\u043F\u0435\u0440\u0430\u0446\u0438\u043E\u043D\u043D\u043E\u0439 \u0421\u0438\u0441\u0442\u0435\u043C\u044B:
+otherClient = \u0414\u0440\u0443\u0433\u043E\u0439 \u043A\u043B\u0438\u0435\u043D\u0442 \u0432 \u043D\u0430\u0441\u0442\u043E\u044F\u0449\u0435\u0435 \u0432\u0440\u0435\u043C\u044F \u043E\u0431\u0441\u043B\u0443\u0436\u0438\u0432\u0430\u0435\u0442\u0441\u044F, \u0432\u0430\u0448 \u0442\u0435\u0441\u0442 \u043D\u0430\u0447\u043D\u0435\u0442\u0441\u044F \u0432 \u0442\u0435\u0447\u0435\u043D\u0438\u0435
+otherTraffic = \u0418\u043D\u0444\u043E\u0440\u043C\u0430\u0446\u0438\u044F: \u041F\u043E\u0441\u0442\u043E\u0440\u043E\u043D\u043D\u0438\u0439 \u0442\u0440\u0430\u0444\u0438\u043A \u0437\u0430\u0431\u0438\u0432\u0430\u0435\u0442 \u0441\u0435\u0442\u0435\u0432\u043E\u0439 \u043B\u0438\u043D\u043A
+outboundTest = Tcpbw100 \u0438\u0441\u0445\u043E\u0434\u044F\u0449\u0438\u0439 \u0442\u0435\u0441\u0442 ...
+outboundWrongMessage = C2S \u0442\u0435\u0441\u0442 \u043D\u0430 \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043D\u0443\u044E \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u044C: \u041F\u043E\u043B\u0443\u0447\u0435\u043D \u043D\u0435\u043F\u0440\u0430\u0432\u0438\u043B\u044C\u043D\u044B\u0439 \u0442\u0438\u043F \u0441\u043E\u043E\u0431\u0449\u0435\u043D\u0438\u044F
+packetQueuing = \u041D\u0430\u043A\u043E\u043F\u043B\u0435\u043D\u0438\u0435 \u043F\u0430\u043A\u0435\u0442\u043E\u0432 \u0432 \u043E\u0447\u0435\u0440\u0435\u0434\u0438
+packetQueuingInfo = TCP (Transmission Control Protocol) \u043D\u0430\u0434\u0435\u0436\u043D\u043E \u043F\u0435\u0440\u0435\u0434\u0430\u0435\u0442 \u0434\u0430\u043D\u043D\u044B\u0435 \u043C\u0435\u0436\u0434\u0443 \u0434\u0432\u0443\u043C\u044F\n \u0445\u043E\u0441\u0442\u0430\u043C\u0438 \u0432 \u0418\u043D\u0442\u0435\u0440\u043D\u0435\u0442\u0435. \u041E\u043D \u0430\u0432\u0442\u043E\u043C\u0430\u0442\u0438\u0447\u0435\u0441\u043A\u0438 \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0438\u0432\u0430\u0435\u0442 \u0438 \u0432\u043E\u0441\u0441\u0442\u0430\u043D\u0430\u0432\u043B\u0438\u0432\u0430\u0435\u0442\u0441\u044F \u043F\u043E\u0441\u043B\u0435 \u043E\u0448\u0438\u0431\u043E\u043A \u0438\n \u043F\u043E\u0442\u0435\u0440\u044C. TCP \u0438\u0441\u043F\u043E\u043B\u044C\u0437\u0443\u0435\u0442 \u0431\u0443\u0444\u0435\u0440\u0438\u0437\u0430\u0446\u0438\u044E \u0447\u0442\u043E\u0431\u044B \u043E\u0431\u0435\u0441\u043F\u0435\u0447\u0438\u0442\u044C \u044D\u0442\u0443 \u043D\u0430\u0434\u0435\u0436\u043D\u043E\u0441\u0442\u044C. \u041A\u0440\u043E\u043C\u0435 \u0442\u043E\u0433\u043E,\n \u0432 \u0441\u0435\u0442\u0435\u0432\u044B\u0445 \u043A\u043E\u043C\u043C\u0443\u0442\u0430\u0442\u043E\u0440\u0430\u0445 \u0438 \u043C\u0430\u0440\u0448\u0440\u0443\u0442\u0438\u0437\u0430\u0442\u043E\u0440\u0430\u0445 \u0438\u0441\u043F\u043E\u043B\u044C\u0437\u0443\u0435\u0442\u0441\u044F \u0431\u0443\u0444\u0435\u0440\u0438\u0437\u0430\u0446\u0438\u044F \u0432 \u0441\u043B\u0443\u0447\u0430\u044F\u0445, \u043A\u043E\u0433\u0434\u0430 \u043D\u0435\u0441\u043A\u043E\u043B\u044C\u043A\u043E \u0432\u0445\u043E\u0434\u044F\u0449\u0438\u0445 \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0439 \n \u043E\u0442\u043F\u0440\u0430\u0432\u043B\u044F\u044E\u0442 \u043F\u0430\u043A\u0435\u0442\u044B \u0432 \u043E\u0434\u043D\u043E \u0438\u0441\u0445\u043E\u0434\u044F\u0449\u0435\u0435 \u0438\u043B\u0438 \u043A\u043E\u0433\u0434\u0430 \u0441\u043A\u043E\u0440\u043E\u0441\u0442\u044C \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u044F \u0438\u0437\u043C\u0435\u043D\u044F\u0435\u0442\u0441\u044F \n (\u043D\u0430\u043F\u0440\u0438\u043C\u0435\u0440 \u0441 FastEthernet \u0434\u043E DSL \u043C\u043E\u0434\u0435\u043C\u0430).\n\n NDT \u0441\u0435\u0440\u0432\u0435\u0440 \u043F\u043E\u0441\u044B\u043B\u0430\u0435\u0442 \u043A\u0430\u0436\u0434\u044B\u0435 10 \u0441\u0435\u043A\u0443\u043D\u0434 \u0434\u0430\u043D\u043D\u044B\u0435 \u043A\u043B\u0438\u0435\u043D\u0442\u0443.\n \u0412 \u043D\u0435\u043A\u043E\u0442\u043E\u0440\u044B\u0445 \u0441\u043B\u0443\u0447\u0430\u044F\u0445 \u0441\u0435\u0440\u0432\u0435\u0440 \u043C\u043E\u0436\u0435\u0442 \u0433\u0435\u043D\u0435\u0440\u0438\u0440\u043E\u0432\u0430\u0442\u044C \u043F\u043E\u0441\u044B\u043B\u0430\u0435\u043C\u044B\u0435 \u0434\u0430\u043D\u043D\u044B\u0435 \u0431\u044B\u0441\u0442\u0440\u0435\u0435, \u0447\u0435\u043C \u043C\u043E\u0436\u0435\u0442 \u043F\u043E\u0441\u044B\u043B\u0430\u0442\u044C \u043F\u0430\u043A\u0435\u0442\u044B\n \u0432 \u0441\u0435\u0442\u044C (\u043D\u0430\u043F\u0440\u0438\u043C\u0435\u0440 \u0432 \u0441\u043B\u0443\u0447\u0430\u0435 \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u0441 \u043F\u0440\u043E\u0446\u0435\u0441\u0441\u043E\u0440\u043E\u043C 2 \u0413\u0413\u0446 \u043E\u0442\u043F\u0440\u0430\u0432\u043B\u044F\u044E\u0449\u0435\u0433\u043E \u0434\u0430\u043D\u043D\u044B\u0435 \u043D\u0430 \u043A\u043B\u0438\u0435\u043D\u0442\u0430 \u0447\u0435\u0440\u0435\u0437 DSL).\n \u041A\u043E\u0433\u0434\u0430 \u044D\u0442\u043E \u0441\u043B\u0443\u0447\u0430\u0435\u0442\u0441\u044F, \u043D\u0435\u043A\u043E\u0442\u043E\u0440\u044B\u0435 \u043F\u0430\u043A\u0435\u0442\u044B \u043C\u043E\u0433\u0443\u0442 \u043E\u0441\u0442\u0430\u0432\u0430\u0442\u044C\u0441\u044F \u043D\u0430 \u0432\u044B\u0445\u043E\u0434\u043D\u043E\u0439 \u043E\u0447\u0435\u0440\u0435\u0434\u044C\u044C\u0438 \u0441\u0435\u0440\u0432\u0435\u0440\u0430\n \u0434\u0430\u0436\u0435 \u043A\u043E\u0433\u0434\u0430 10-\u0442\u0438 \u0441\u0435\u043A\u0443\u043D\u0434\u043D\u044B\u0439 \u0442\u0430\u0439\u043C\u0435\u0440 \u0438\u0441\u0442\u0435\u0447\u0435\u0442. TCP \u0430\u0432\u0442\u043E\u043C\u0430\u0442\u0438\u0447\u0435\u0441\u043A\u0438 \u043F\u0440\u043E\u0434\u043E\u043B\u0436\u0438\u0442\n \u043E\u0442\u043F\u0440\u0430\u0432\u043B\u044F\u0442\u044C \u044D\u0442\u0438 \u043F\u0430\u043A\u0435\u0442\u044B \u0438\u0437 \u043E\u0447\u0435\u0440\u0435\u0434\u0438, \u0438 \u043A\u043B\u0438\u0435\u043D\u0442 \u0431\u0443\u0434\u0435\u0442 \u043F\u0440\u043E\u0434\u043E\u043B\u0436\u0430\u0442\u044C \u043F\u0440\u0438\u043D\u0438\u043C\u0430\u0442\u044C \u0438\n \u043E\u0431\u0440\u0430\u0431\u043E\u0442\u0430\u0442\u044C \u044D\u0442\u0438 \u0432\u0445\u043E\u0434\u044F\u0449\u0438\u0435 \u043F\u0430\u043A\u0435\u0442\u044B. \u042D\u0442\u043E \u043F\u0440\u0438\u0432\u0435\u0434\u0435\u0442 \u043A\n \u0442\u043E\u043C\u0443 \u0447\u0442\u043E \u0442\u0435\u0441\u0442 \u043C\u043E\u0436\u0435\u0442 \u0437\u0430\u0442\u044F\u043D\u0443\u0442\u044C\u0441\u044F.\n\n \u042D\u0442\u043E \u0441\u043B\u0443\u0447\u0438\u043B\u043E\u0441\u044C \u0432\u043E \u0432\u0440\u0435\u043C\u044F \u044D\u0442\u043E\u0433\u043E \u0442\u0435\u0441\u0442\u0430. \u041D\u0438\u043A\u0430\u043A\u0438\u0445 \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0439 \u043F\u0440\u0435\u0434\u043F\u0440\u0438\u043D\u0438\u043C\u0430\u0442\u044C \u043D\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442\u0441\u044F, \u0447\u0442\u043E\u0431\u044B\n \u0440\u0435\u0448\u0438\u0442\u044C \u044D\u0442\u0443 \u043F\u0440\u043E\u0431\u043B\u0435\u043C\u0443.
+packetSizePreserved = \u0420\u0430\u0437\u043C\u0435\u0440 \u043F\u0430\u043A\u0435\u0442\u0430 \u043D\u0435 \u0438\u0437\u043C\u0435\u043D\u0438\u043B\u0441\u044F \u043D\u0430 \u0432\u0441\u0435\u043C \u043F\u0443\u0442\u0438
+packetsize = \u0440\u0430\u0437\u043C\u0435\u0440 \u043F\u0430\u043A\u0435\u0442\u0430
+pc = \u041F\u041A
+pctOfTime =% \u0432\u0440\u0435\u043C\u0435\u043D\u0438
+performedTests = \u0417\u0430\u043A\u043E\u043D\u0447\u0435\u043D\u043D\u044B\u0435 \u0442\u0435\u0441\u0442\u044B
+pktsRetrans = \u043F\u0430\u043A\u0435\u0442\u044B \u043F\u0435\u0440\u0435\u0441\u043B\u0430\u043D\u043D\u044B\u0435 \u043F\u043E\u0432\u0442\u043E\u0440\u043D\u043E
+possibleDuplexFullHalf = \u0412\u043D\u0438\u043C\u0430\u043D\u0438\u0435: \u041E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E \u0412\u043E\u0437\u043C\u043E\u0436\u043D\u043E\u0435 \u041D\u0435\u0441\u043E\u0432\u043F\u0430\u0434\u0435\u043D\u0438\u0435 \u0434\u0443\u043F\u043B\u0435\u043A\u0441\u0430 Switch=\u0434\u0443\u043F\u043B\u0435\u043A\u0441 \u0438 Host=\u043F\u043E\u043B\u0443\u0434\u0443\u043F\u043B\u0435\u043A\u0441
+possibleDuplexHalfFull = \u0412\u043D\u0438\u043C\u0430\u043D\u0438\u0435: \u041E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E \u0412\u043E\u0437\u043C\u043E\u0436\u043D\u043E\u0435 \u041D\u0435\u0441\u043E\u0432\u043F\u0430\u0434\u0435\u043D\u0438\u0435 \u0434\u0443\u043F\u043B\u0435\u043A\u0441\u0430 Switch=\u043F\u043E\u043B\u0443\u0434\u0443\u043F\u043B\u0435\u043A\u0441 \u0438 Host=\u0434\u0443\u043F\u043B\u0435\u043A\u0441
+possibleDuplexHalfFullWarning = \u041F\u0440\u0435\u0434\u0443\u043F\u0440\u0435\u0436\u0434\u0435\u043D\u0438\u0435: \u041E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E \u0412\u043E\u0437\u043C\u043E\u0436\u043D\u043E\u0435 \u041D\u0435\u0441\u043E\u0432\u043F\u0430\u0434\u0435\u043D\u0438\u0435 \u0434\u0443\u043F\u043B\u0435\u043A\u0441\u0430 Switch=\u043F\u043E\u043B\u0443\u0434\u0443\u043F\u043B\u0435\u043A\u0441 \u0438 Host=\u0434\u0443\u043F\u043B\u0435\u043A\u0441
+preferIPv6 = \u043F\u0440\u0435\u0434\u043F\u043E\u0447\u0438\u0442\u0435\u043D\u0438\u0435 IPv6
+printDetailedStats = \u041D\u0430\u043F\u0435\u0447\u0430\u0442\u0430\u0442\u044C \u041F\u043E\u0434\u0440\u043E\u0431\u043D\u0443\u044E \u0421\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043A\u0443
+protocolError = \u041E\u0448\u0438\u0431\u043A\u0430 \u043F\u0440\u043E\u0442\u043E\u043A\u043E\u043B\u0430! \u041E\u0436\u0438\u0434\u0430\u043B\u043E\u0441\u044C 'prepare', \u043F\u043E\u043B\u0443\u0447\u0438\u043B\u0438: 0x
+qSeen = \u0442\u0435\u0441\u0442 \u043D\u0430 \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043D\u0443\u044E \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u044C: \u041E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E \u043D\u0430\u043A\u043E\u043F\u043B\u0435\u043D\u0438\u0435 \u043F\u0430\u043A\u0435\u0442\u043E\u0432 \u0432 \u043E\u0447\u0435\u0440\u0435\u0434\u0438
+ready = Tcpbw100 \u0433\u043E\u0442\u043E\u0432
+receiveBufferShouldBe = \u0418\u043D\u0444\u043E\u0440\u043C\u0430\u0446\u0438\u044F: \u041F\u0440\u0438\u0435\u043C\u043D\u044B\u0439 \u0431\u0443\u0444\u0435\u0440 \u0434\u043E\u043B\u0436\u0435\u043D \u0431\u044B\u0442\u044C
+receiving = \u041F\u043E\u043B\u0443\u0447\u0435\u043D\u0438\u0435 \u0440\u0435\u0437\u0443\u043B\u044C\u0442\u0430\u0442\u043E\u0432 ...
+reportProblem = \u0421\u043E\u043E\u0431\u0449\u0438\u0442\u044C \u043E \u043F\u0440\u043E\u0431\u043B\u0435\u043C\u0435
+resultsParseError = \u041E\u0448\u0438\u0431\u043A\u0430 \u043F\u0440\u0438 \u0440\u0430\u0437\u0431\u043E\u0440\u0435 \u0440\u0435\u0437\u0443\u043B\u044C\u0442\u0430\u0442\u043E\u0432 \u0442\u0435\u0441\u0442\u0438\u0440\u043E\u0432\u0430\u043D\u0438\u044F!
+resultsTimeout = \u041F\u0440\u0435\u0434\u0443\u043F\u0440\u0435\u0436\u0434\u0435\u043D\u0438\u0435! \u041A\u043B\u0438\u0435\u043D\u0442 \u043E\u0442\u0432\u0430\u043B\u0438\u043B\u0441\u044F \u043F\u043E \u0442\u0430\u0439\u043C-\u0430\u0443\u0442\u0443 \u043F\u0440\u0438 \u0447\u0442\u0435\u043D\u0438\u0438 \u0434\u0430\u043D\u043D\u044B\u0445, \u0432\u043E\u0437\u043C\u043E\u0436\u043D\u043E \u043D\u0435\u0441\u043E\u043E\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0438\u0435 \u0434\u0443\u043F\u043B\u0435\u043A\u0441\u0430
+resultsWrongMessage = \u0420\u0435\u0437\u0443\u043B\u044C\u0442\u0430\u0442\u044B \u0442\u0435\u0441\u0442\u043E\u0432: \u041F\u043E\u043B\u0443\u0447\u0435\u043D \u043D\u0435\u043F\u0440\u0430\u0432\u0438\u043B\u044C\u043D\u044B\u0439 \u0442\u0438\u043F \u0441\u043E\u043E\u0431\u0449\u0435\u043D\u0438\u044F
+rtt = RTT
+rttFail = \u0430\u043B\u0433\u043E\u0440\u0438\u0442\u043C \u043E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u0438\u044F \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u044F \u043D\u0435 \u0441\u0440\u0430\u0431\u043E\u0442\u0430\u043B \u0438\u0437-\u0437\u0430 \u0447\u0440\u0435\u0437\u043C\u0435\u0440\u043D\u043E\u0439 \u0434\u0432\u0443\u0445\u0441\u0442\u043E\u0440\u043E\u043D\u043D\u0435\u0439 \u0437\u0430\u0434\u0435\u0440\u0436\u043A\u0438 (RTT).
+runningInboundTest = \u0440\u0430\u0431\u043E\u0442\u0430\u0435\u0442 10-\u0442\u0438 \u0441\u0435\u043A\u0443\u043D\u0434\u043D\u044B\u0439 \u0442\u0435\u0441\u0442 \u0432\u0445\u043E\u0434\u044F\u0449\u0438\u0445 \u043F\u0430\u043A\u0435\u0442\u043E\u0432 (\u043E\u0442 \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u043A \u043A\u043B\u0438\u0435\u043D\u0442\u0443 [S2C]). . . . . .
+runningOutboundTest = \u0440\u0430\u0431\u043E\u0442\u0430\u0435\u0442 10-\u0442\u0438 \u0441\u0435\u043A\u0443\u043D\u0434\u043D\u044B\u0439 \u0442\u0435\u0441\u0442 \u0438\u0441\u0445\u043E\u0434\u044F\u0449\u0438\u0445 \u043F\u0430\u043A\u0435\u0442\u043E\u0432 (\u043A\u043B\u0438\u0435\u043D\u0442-\u0441\u0435\u0440\u0432\u0435\u0440 [C2S]). . . . .
+S2C = S2C
+s2cPacketQueuingDetected = [S2C]: \u041E\u0431\u043D\u0430\u0440\u0443\u0436\u0435\u043D\u043E \u043D\u0430\u043A\u043E\u043F\u043B\u0435\u043D\u0438\u0435 \u043F\u0430\u043A\u0435\u0442\u043E\u0432 \u0432 \u043E\u0447\u0435\u0440\u0435\u0434\u0438
+s2cThroughput = S2C \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043D\u0430\u044F \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u044C
+s2cThroughputFailed = S2C \u0442\u0435\u0441\u0442 \u043D\u0430 \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043D\u0443\u044E \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u044C \u041D\u0415 \u0421\u0420\u0410\u0411\u041E\u0422\u0410\u041B !
+sackReceived = \u0431\u043B\u043E\u043A\u0438 SACK \u043F\u043E\u043B\u0443\u0447\u0435\u043D\u044B
+scalingFactors = \u0424\u0430\u043A\u0442\u043E\u0440\u044B \u041C\u0430\u0441\u0448\u0442\u0430\u0431\u0438\u0440\u043E\u0432\u0430\u043D\u0438\u044F
+seconds = \u0441\u0435\u043A\u0443\u043D\u0434
+server = \u0421\u0435\u0440\u0432\u0435\u0440
+serverAcksReport = \u0421\u0435\u0440\u0432\u0435\u0440 \u043E\u0442\u0432\u0435\u0442\u0438\u043B \u0441 Ack \u0447\u0442\u043E \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435
+serverBusy = \u0421\u0435\u0440\u0432\u0435\u0440 \u0437\u0430\u043D\u044F\u0442: \u0421\u043B\u0438\u0448\u043A\u043E\u043C \u043C\u043D\u043E\u0433\u043E \u043A\u043B\u0438\u0435\u043D\u0442\u043E\u0432 \u043E\u0436\u0438\u0434\u0430\u044E\u0442 \u0432 \u043E\u0447\u0435\u0440\u0435\u0434\u0438 \u0441\u0435\u0440\u0432\u0435\u0440\u0430. \u041F\u043E\u0436\u0430\u043B\u0443\u0439\u0441\u0442\u0430, \u043F\u043E\u0432\u0442\u043E\u0440\u0438\u0442\u0435 \u043F\u043E\u043F\u044B\u0442\u043A\u0443 \u043F\u043E\u0437\u0436\u0435
+serverBusy15s = \u0421\u0435\u0440\u0432\u0435\u0440 \u0437\u0430\u043D\u044F\u0442: \u041F\u043E\u0436\u0430\u043B\u0443\u0439\u0441\u0442\u0430, \u043F\u043E\u0434\u043E\u0436\u0434\u0438\u0442\u0435 15 \u0441\u0435\u043A\u0443\u043D\u0434 \u043F\u043E\u043A\u0430 \u0437\u0430\u043A\u043E\u043D\u0447\u0438\u0442\u0441\u044F \u043F\u0440\u0435\u0434\u044B\u0434\u0443\u0449\u0438\u0439 \u0442\u0435\u0441\u0442
+serverBusy30s = \u0421\u0435\u0440\u0432\u0435\u0440 \u0437\u0430\u043D\u044F\u0442: \u041F\u043E\u0436\u0430\u043B\u0443\u0439\u0441\u0442\u0430, \u043F\u043E\u0434\u043E\u0436\u0434\u0438\u0442\u0435 30 \u0441\u0435\u043A\u0443\u043D\u0434 \u043F\u043E\u043A\u0430 \u0437\u0430\u043A\u043E\u043D\u0447\u0438\u0442\u0441\u044F \u043F\u0440\u0435\u0434\u044B\u0434\u0443\u0449\u0438\u0439 \u0442\u0435\u0441\u0442
+serverBusy60s = \u0421\u0435\u0440\u0432\u0435\u0440 \u0437\u0430\u043D\u044F\u0442: \u041F\u043E\u0436\u0430\u043B\u0443\u0439\u0441\u0442\u0430, \u043F\u043E\u0434\u043E\u0436\u0434\u0438\u0442\u0435 60 \u0441\u0435\u043A\u0443\u043D\u0434 \u043F\u043E\u043A\u0430 \u0437\u0430\u043A\u043E\u043D\u0447\u0438\u0442\u0441\u044F \u043F\u0440\u0435\u0434\u044B\u0434\u0443\u0449\u0438\u0439 \u0442\u0435\u0441\u0442
+serverDataReports = \u0414\u0430\u043D\u043D\u044B\u0435 \u0441 \u0421\u0435\u0440\u0432\u0435\u0440\u0430 \u043F\u043E\u0434\u0442\u0432\u0435\u0440\u0436\u0434\u0430\u044E\u0442 \u0447\u0442\u043E \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435
+serverFail Server = \u041E\u0448\u0438\u0431\u043A\u0430 \u043F\u0440\u0438 \u043F\u043E\u043B\u0443\u0447\u0435\u043D\u0438\u0438 \u0434\u0430\u043D\u043D\u044B\u0445
+serverIpModified = \u0418\u043D\u0444\u043E\u0440\u043C\u0430\u0446\u0438\u044F: \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E \u043F\u0440\u0435\u043E\u0431\u0440\u0430\u0437\u043E\u0432\u0430\u043D\u0438\u044F \u0441\u0435\u0442\u0435\u0432\u044B\u0445 \u0430\u0434\u0440\u0435\u0441\u043E\u0432 (NAT) \u0438\u0437\u043C\u0435\u043D\u044F\u0435\u0442 IP-\u0430\u0434\u0440\u0435\u0441 \u043A\u043B\u0438\u0435\u043D\u0442\u0430
+serverIpPreserved = IP \u0430\u0434\u0440\u0435\u0441\u0430 \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u0431\u044B\u043B\u0438 \u0441\u043E\u0445\u0440\u0430\u043D\u0435\u043D\u044B \u0431\u0435\u0437 \u0438\u0437\u043C\u0435\u043D\u0435\u043D\u0438\u0439 \u043D\u0430 \u0432\u0441\u0435\u043C \u043F\u0443\u0442\u0438
+serverNotRunning = \u0421\u0435\u0440\u0432\u0435\u0440\u043D\u044B\u0439 \u043F\u0440\u043E\u0446\u0435\u0441\u0441 \u043D\u0435 \u0440\u0430\u0431\u043E\u0442\u0430\u0435\u0442: \u0437\u0430\u043F\u0443\u0441\u0442\u0438\u0442\u0435 \u043F\u0440\u043E\u0446\u0435\u0441\u0441 web100srv \u043D\u0430 \u0443\u0434\u0430\u043B\u0435\u043D\u043D\u043E\u043C \u0441\u0435\u0440\u0432\u0435\u0440\u0435
+serverSays = \u0421\u0435\u0440\u0432\u0435\u0440 \u0441\u043E\u043E\u0431\u0449\u0430\u0435\u0442
+sfwFail = \u041F\u0440\u043E\u0441\u0442\u043E\u0439 \u0442\u0435\u0441\u0442 \u043D\u0430 \u043C\u0435\u0436\u0441\u0435\u0442\u0435\u0432\u043E\u0439 \u044D\u043A\u0440\u0430\u043D \u041D\u0415 \u041F\u0420\u041E\u0428\u0415\u041B!
+sfwSocketFail = \u041F\u0440\u043E\u0441\u0442\u043E\u0439 \u0442\u0435\u0441\u0442 \u043D\u0430 \u043C\u0435\u0436\u0441\u0435\u0442\u0435\u0432\u043E\u0439 \u044D\u043A\u0440\u0430\u043D: \u041D\u0435\u0432\u043E\u0437\u043C\u043E\u0436\u043D\u043E \u0441\u043E\u0437\u0434\u0430\u0442\u044C \u0441\u0435\u0440\u0432\u0435\u0440\u043D\u044B\u0439 \u043F\u0440\u043E\u0433\u0440\u0430\u043C\u043C\u043D\u044B\u0439 \u0438\u043D\u0442\u0435\u0440\u0444\u0435\u0439\u0441 (socket)
+sfwTest = \u041F\u0440\u043E\u0441\u0442\u043E\u0439 \u0442\u0435\u0441\u0442 \u043D\u0430 \u043C\u0435\u0436\u0441\u0435\u0442\u0435\u0432\u043E\u0439 \u044D\u043A\u0440\u0430\u043D...
+sfwWrongMessage = \u041F\u0440\u043E\u0441\u0442\u043E\u0439 \u0442\u0435\u0441\u0442 \u043D\u0430 \u043C\u0435\u0436\u0441\u0435\u0442\u0435\u0432\u043E\u0439 \u044D\u043A\u0440\u0430\u043D: \u041F\u043E\u043B\u0443\u0447\u0435\u043D \u043D\u0435\u043F\u0440\u0430\u0432\u0438\u043B\u044C\u043D\u044B\u0439 \u0442\u0438\u043F \u0441\u043E\u043E\u0431\u0449\u0435\u043D\u0438\u044F
+showOptions = \u041F\u043E\u043A\u0430\u0437\u0430\u0442\u044C \u043D\u0430\u0441\u0442\u0440\u043E\u0439\u043A\u0438
+simpleFirewall = \u041F\u0440\u043E\u0441\u0442\u043E\u0439 \u043C\u0435\u0436\u0441\u0435\u0442\u0435\u0432\u043E\u0439 \u044D\u043A\u0440\u0430\u043D
+sleep10m = \u0417\u0430\u0434\u0440\u0435\u043C\u0430\u043B \u043D\u0430 10 \u043C\u0438\u043D\u0443\u0442 ...
+sleep1m = \u0417\u0430\u0434\u0440\u0435\u043C\u0430\u043B \u043D\u0430 1 \u043C\u0438\u043D ...
+sleep30m = \u0417\u0430\u0434\u0440\u0435\u043C\u0430\u043B \u043D\u0430 30 \u043C\u0438\u043D\u0443\u0442 ...
+sleep5m = \u0417\u0430\u0434\u0440\u0435\u043C\u0430\u043B \u043D\u0430 5 \u043C\u0438\u043D\u0443\u0442 ...
+sleep12h = \u0417\u0430\u0434\u0440\u0435\u043C\u0430\u043B \u043D\u0430 12 \u0447\u0430\u0441\u043E\u0432 ...
+sleep1d = \u0417\u0430\u0434\u0440\u0435\u043C\u0430\u043B \u043D\u0430 1 \u0434\u0435\u043D\u044C ...
+sleep2h = \u0417\u0430\u0434\u0440\u0435\u043C\u0430\u043B \u043D\u0430 2 \u0447\u0430\u0441\u0430 ...
+start = \u0421\u0422\u0410\u0420\u0422
+startingTest = \u041D\u0430\u0447\u0438\u043D\u0430\u0435\u043C \u0442\u0435\u0441\u0442\u0438\u0440\u043E\u0432\u0430\u043D\u0438\u0435
+statistics = \u0421\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043A\u0430
+stop = \u0421\u0422\u041E\u041F
+stopped = \u0422\u0435\u0441\u0442\u044B \u0431\u044B\u043B\u0438 \u043E\u0441\u0442\u0430\u043D\u043E\u0432\u043B\u0435\u043D\u044B!
+stopping = O\u0441\u0442\u0430\u043D\u0430\u0432\u043B\u0438\u0432\u0430\u0435\u043C\u0441\u044F...
+systemFault = \u0421\u0438\u0441\u0442\u0435\u043C\u043D\u0430\u044F \u043D\u0435\u043F\u043E\u043B\u0430\u0434\u043A\u0430
+test = \u0422\u0415\u0421\u0422
+testsuiteWrongMessage = \u041E\u0431\u043C\u0435\u043D \u0441\u043E\u043E\u0431\u0448\u0435\u043D\u0438\u0439 \u043E \u043D\u0430\u0431\u043E\u0440\u0435 \u0442\u0435\u0441\u0442\u043E\u0432: \u041F\u043E\u043B\u0443\u0447\u0435\u043D \u043D\u0435\u043F\u0440\u0430\u0432\u0438\u043B\u044C\u043D\u044B\u0439 \u0442\u0438\u043F \u0441\u043E\u043E\u0431\u0449\u0435\u043D\u0438\u044F
+theSlowestLink = \u0421\u0430\u043C\u043E\u0435 \u043C\u0435\u0434\u043B\u0435\u043D\u043D\u043E\u0435 \u0437\u0432\u0435\u043D\u043E \u043D\u0430 \u0432\u0441\u0435\u043C \u043F\u0440\u043E\u0442\u044F\u0436\u0435\u043D\u0438\u0438 \u0441\u0435\u0442\u0438
+theoreticalLimit = \u0422\u0435\u043E\u0440\u0435\u0442\u0438\u0447\u0435\u0441\u043A\u0438\u0439 \u043F\u0440\u0435\u0434\u0435\u043B \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043D\u043E\u0439 \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u0438 \u0441\u0435\u0442\u0438
+thisConnIs = \u042D\u0442\u043E \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0435
+timesPktLoss = \u0440\u0430\u0437 \u0438\u0437-\u0437\u0430 \u043F\u043E\u0442\u0435\u0440\u0438 \u043F\u0430\u043A\u0435\u0442\u043E\u0432
+toMaximizeThroughput = \u043A\u0431\u0430\u0439\u0442 \u0447\u0442\u043E\u0431\u044B \u0443\u0432\u0435\u043B\u0438\u0447\u0438\u0442\u044C \u043F\u0440\u043E\u043F\u0443\u0441\u043A\u043D\u0443\u044E \u0441\u043F\u043E\u0441\u043E\u0431\u043D\u043E\u0441\u0442\u044C \u0441\u0435\u0442\u0438
+troubleReportFrom = \u041E\u0442\u0447\u0435\u0442 \u0418\u0421\u0414 \u043E \u043D\u0430\u0439\u0434\u0435\u043D\u043D\u044B\u0445 \u043F\u0440\u043E\u0431\u043B\u0435\u043C\u0430\u0445 \u043D\u0430
+unableToDetectBottleneck = \u0421\u0435\u0440\u0432\u0435\u0440 \u043D\u0435 \u043C\u043E\u0436\u0435\u0442 \u043E\u043F\u0440\u0435\u0434\u0435\u043B\u0438\u0442\u044C \u0442\u0438\u043F \u0441\u0435\u0442\u0435\u0432\u043E\u0433\u043E \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u044F \u043D\u0430 \u0441\u0430\u043C\u043E\u043C \u043C\u0435\u0434\u043B\u0435\u043D\u043D\u043E\u043C \u0437\u0432\u0435\u043D\u0435 \u0441\u0435\u0442\u0438.
+unableToObtainIP = \u041D\u0435\u0432\u043E\u0437\u043C\u043E\u0436\u043D\u043E \u043F\u043E\u043B\u0443\u0447\u0438\u0442\u044C \u043B\u043E\u043A\u0430\u043B\u044C\u043D\u044B\u0439 IP \u0430\u0434\u0440\u0435\u0441
+unknownID = \u041D\u0435\u0438\u0437\u0432\u0435\u0441\u0442\u043D\u044B\u0439 \u0438\u0434\u0435\u043D\u0442\u0438\u0444\u0438\u043A\u0430\u0442\u043E\u0440(ID) \u0442\u0435\u0441\u0442\u0430
+unknownServer = \u0421\u0435\u0440\u0432\u0435\u0440 \u043D\u0435\u0438\u0437\u0432\u0435\u0441\u0442\u0435\u043D
+unsupportedClient = \u0418\u043D\u0444\u043E\u0440\u043C\u0430\u0446\u0438\u044F: \u0441\u0435\u0440\u0432\u0435\u0440 \u043D\u0435 \u043F\u043E\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u044D\u0442\u043E\u0433\u043E \u043A\u043E\u043C\u043C\u0430\u043D\u0434\u043D\u043E\u0433\u043E \u043A\u043B\u0438\u0435\u043D\u0442\u0430
+vendor = \u041F\u0440\u043E\u0438\u0437\u0432\u043E\u0434\u0438\u0442\u0435\u043B\u044C
+version = \u0412\u0435\u0440\u0441\u0438\u044F
+versionWrongMessage = \u0412\u044B\u044F\u0441\u043D\u0435\u043D\u0438\u0435 \u0432\u0435\u0440\u0441\u0438\u0438 \u0418\u0421\u0414: \u041F\u043E\u043B\u0443\u0447\u0435\u043D \u043D\u0435\u043F\u0440\u0430\u0432\u0438\u043B\u044C\u043D\u044B\u0439 \u0442\u0438\u043F \u0441\u043E\u043E\u0431\u0449\u0435\u043D\u0438\u044F
+web100Details = WEB100 \u041F\u043E\u0434\u0440\u043E\u0431\u043D\u044B\u0439 \u041E\u0442\u0447\u0435\u0442
+web100KernelVar = WEB100 \u043F\u0435\u0440\u0435\u043C\u0435\u043D\u043D\u044B\u0435 \u044F\u0434\u0440\u0430
+web100Stats = WEB100 \u0421\u0442\u0430\u0442\u0438\u0441\u0442\u0438\u043A\u0430 \u0432\u043A\u043B\u044E\u0447\u0435\u043D\u0430
+web100Var = WEB100 \u043F\u0435\u0440\u0435\u043C\u0435\u043D\u043D\u044B\u0435
+web100rtt = WEB100 \u0441\u043E\u043E\u0431\u0449\u0430\u0435\u0442 \u043E \u0442\u0443\u0434\u0430-\u043E\u0431\u0440\u0430\u0442\u043D\u043E\u0439 \u0437\u0430\u0434\u0435\u0440\u0436\u043A\u0435 (RTT)
+web100tcpOpts = WEB100 \u0441\u043E\u043E\u0431\u0449\u0430\u0435\u0442 \u043E \u0442\u043E\u043C \u0447\u0442\u043E \u0432 \u0440\u0435\u0437\u0443\u043B\u044C\u0442\u0430\u0442\u0435 \u043E\u0431\u043C\u0435\u043D\u0430 TCP \u0431\u044B\u043B\u0438 \u043D\u0430\u0439\u0434\u0435\u043D\u044B \u0434\u043E\u043F\u043E\u043B\u043D\u0438\u0442\u0435\u043B\u044C\u043D\u044B\u0435 \u043F\u0430\u0440\u0430\u043C\u0435\u0442\u0440\u044B \u043F\u0440\u043E\u0438\u0437\u0432\u043E\u0434\u0438\u0442\u0435\u043B\u044C\u043D\u043E\u0441\u0442\u0438:
+willImprove = \u043F\u043E\u0437\u0432\u043E\u043B\u0438\u0442 \u043F\u043E\u0432\u044B\u0441\u0438\u0442\u044C \u043F\u0440\u043E\u0438\u0437\u0432\u043E\u0434\u0438\u0442\u0435\u043B\u044C\u043D\u043E\u0441\u0442\u044C \u0441\u043E\u0435\u0434\u0438\u043D\u0435\u043D\u0438\u0439
+workstation = \u0420\u0430\u0431\u043E\u0447\u0430\u044F \u0421\u0442\u0430\u043D\u0446\u0438\u044F
+your = \u0412\u0430\u0448
+yourPcHas = \u0423 \u0412\u0430\u0448\u0435\u0433\u043E \u041F\u041A/\u0420\u0430\u0431\u043E\u0447\u0435\u0439 \u0421\u0442\u0430\u043D\u0446\u0438\u0438 \u0435\u0441\u0442\u044C
+connectingTo = \u041F\u043E\u0434\u043A\u043B\u044E\u0447\u0430\u0435\u043C\u0441\u044F \u043A
+toRunTest = \u043F\u0440\u043E\u0432\u0435\u0441\u0442\u0438 \u0442\u0435\u0441\u0442
=======================================
--- /dev/null
+++ /branches/SamKnows/src/main.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,91 @@
+import skin.*;
+import skin.Button;
+import skin.Image;
+import skin.Label;
+
+import javax.swing.*;
+import java.awt.*;
+
+public class main {
+ public static void main(String[] args) {
+
+ Interface skin = new Interface();
+
+ skin.setMainBackgroundImage(new Image(new Rectangle(0, 0, 600, 400), "META-INF/background.jpg", true));
+ skin.setBackground1Image(new Image(new Rectangle(30, 10, 260, 260), "META-INF/speedbackground.png", true));
+// skin.setBackground2Image(new Image(new Rectangle(310, 10, 260, 260), "META-INF/speedbackground.png", true));
+ skin.setValue1Label(new Label(new Rectangle(115, 232, 87, 20), Color.GREEN, new Font("Arial", Font.BOLD, 12), SwingConstants.LEFT, true));
+ skin.setValue2Label(new Label(new Rectangle(395, 232, 87, 20), Color.RED, new Font("Arial", Font.BOLD, 12), SwingConstants.CENTER, true));
+ skin.setStatusLabel(new Label(new Rectangle(200, 275, 200, 20), Color.CYAN, new Font("Arial", Font.BOLD | Font.ITALIC, 12), SwingConstants.RIGHT, true));
+ skin.setRttLabel(new Label(new Rectangle(400, 50, 100, 20), Color.CYAN, new Font("Arial", Font.BOLD | Font.ITALIC, 12), SwingConstants.LEADING, true));
+ skin.setLossLabel(new Label(new Rectangle(400, 100, 100, 20), Color.CYAN, new Font("Arial", Font.BOLD | Font.ITALIC, 12), SwingConstants.TRAILING, true));
+
+ skin.setPreparingTestString("Preparing speed test");
+ skin.setFirewallTestString("Simple firewall test");
+ skin.setUploadTestString("Upload test");
+ skin.setDownloadTestString("Download test");
+ skin.setCompleteTestString("Complete");
+
+ Button btn = new skin.Button("Start");
+ btn.setRect(new Rectangle(100, 300, 120, 50));
+ btn.setImageName("META-INF/button1.png");
+ btn.setPressedImageName("META-INF/button2.png");
+ btn.setTextColor(Color.RED);
+ btn.setTextFont(new Font("Arial", Font.ITALIC, 20));
+ skin.setStartButton(btn);
+ btn = new Button("Stop");
+ btn.setRect(new Rectangle(240, 300, 120, 50));
+ btn.setImageName("META-INF/button1.png");
+ btn.setPressedImageName("META-INF/button2.png");
+ btn.setTextColor(Color.GREEN);
+ btn.setTextFont(new Font("Arial", Font.ITALIC, 20));
+ skin.setStopButton(btn);
+ btn = new Button("Advanced");
+ btn.setRect(new Rectangle(380, 300, 120, 50));
+ btn.setImageName("META-INF/button1.png");
+ btn.setPressedImageName("META-INF/button2.png");
+ btn.setTextColor(Color.BLUE);
+ btn.setTextFont(new Font("Arial", Font.ITALIC, 20));
+ skin.setAdvancedButton(btn);
+
+ TextPane pane = new TextPane();
+ pane.setX(120);
+ pane.setY(350);
+ pane.setW(560);
+ pane.setH(150);
+ skin.setTextPane(pane);
+
+ Arrow arrow = new Arrow();
+ arrow.setArrowX(160);
+ arrow.setArrowY(140);
+ arrow.setArrowAnchorX(5);
+ arrow.setArrowAnchorY(5);
+ arrow.setFirstAngle(150);
+ arrow.setLastAngle(390);
+ arrow.setScales(new int[]{0, 50, 100, 300, 500, 1000, 2000, 4000, 8000, 16000, 30000, 50000, 100000});
+ arrow.setArrowImageName("META-INF/arrow.png");
+ arrow.setVisible(true);
+ skin.setArrow1(arrow);
+
+// arrow = new Arrow();
+// arrow.setArrowX(440);
+// arrow.setArrowY(140);
+// arrow.setArrowAnchorX(5);
+// arrow.setArrowAnchorY(5);
+// arrow.setFirstAngle(150);
+// arrow.setLastAngle(390);
+// arrow.setScales(new int[] {0, 50, 100, 300, 500, 1000, 2000, 4000, 8000, 16000, 30000, 50000, 100000});
+// arrow.setArrowImageName("META-INF/arrow.png");
+// arrow.setVisible(false);
+// skin.setArrow2(arrow);
+
+ skin.save("d:\\interface.properties");
+
+// SwingUtilities.invokeLater(new Runnable() {
+// public void run() {
+// new MainForm().setVisible(true);
+// }
+// });
+
+ }
+}
=======================================
--- /dev/null
+++ /branches/SamKnows/src/skin/Arrow.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,99 @@
+package skin;
+
+import java.io.Serializable;
+
+public class Arrow implements Serializable {
+ private int arrowX;
+ private int arrowY;
+ private int arrowAnchorX;
+ private int arrowAnchorY;
+ private int firstAngle;
+ private int lastAngle;
+ private int[] scales;
+ private String arrowImageName;
+ private java.awt.Image arrowImage;
+ private boolean visible;
+
+ public Arrow() {
+ }
+
+ public int getArrowX() {
+ return arrowX;
+ }
+
+ public void setArrowX(final int arrowX) {
+ this.arrowX = arrowX;
+ }
+
+ public int getArrowY() {
+ return arrowY;
+ }
+
+ public void setArrowY(final int arrowY) {
+ this.arrowY = arrowY;
+ }
+
+ public int getArrowAnchorX() {
+ return arrowAnchorX;
+ }
+
+ public void setArrowAnchorX(final int arrowAnchorX) {
+ this.arrowAnchorX = arrowAnchorX;
+ }
+
+ public int getArrowAnchorY() {
+ return arrowAnchorY;
+ }
+
+ public void setArrowAnchorY(final int arrowAnchorY) {
+ this.arrowAnchorY = arrowAnchorY;
+ }
+
+ public int getFirstAngle() {
+ return firstAngle;
+ }
+
+ public void setFirstAngle(final int firstAngle) {
+ this.firstAngle = firstAngle;
+ }
+
+ public int getLastAngle() {
+ return lastAngle;
+ }
+
+ public void setLastAngle(final int lastAngle) {
+ this.lastAngle = lastAngle;
+ }
+
+ public int[] getScales() {
+ return scales;
+ }
+
+ public void setScales(final int[] scales) {
+ this.scales = scales;
+ }
+
+ public String getArrowImageName() {
+ return arrowImageName;
+ }
+
+ public void setArrowImageName(final String arrowImageName) {
+ this.arrowImageName = arrowImageName;
+ }
+
+ public java.awt.Image getArrowImage() {
+ return arrowImage;
+ }
+
+ public void setArrowImage(final java.awt.Image arrowImage) {
+ this.arrowImage = arrowImage;
+ }
+
+ public boolean isVisible() {
+ return visible;
+ }
+
+ public void setVisible(final boolean visible) {
+ this.visible = visible;
+ }
+}
=======================================
--- /dev/null
+++ /branches/SamKnows/src/skin/Button.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,89 @@
+package skin;
+
+import java.awt.*;
+import java.io.Serializable;
+
+public class Button implements Serializable {
+ private Rectangle rect;
+
+ private Color textColor;
+ private Font textFont;
+
+ private String text;
+ private String imageName;
+ private String pressedImageName;
+
+ private java.awt.Image image;
+ private java.awt.Image pressedImage;
+
+ public Button() {
+ }
+
+ public Button(final String text) {
+ this.text = text;
+ }
+
+ public Rectangle getRect() {
+ return rect;
+ }
+
+ public void setRect(final Rectangle rect) {
+ this.rect = rect;
+ }
+
+ public Color getTextColor() {
+ return textColor;
+ }
+
+ public void setTextColor(final Color textColor) {
+ this.textColor = textColor;
+ }
+
+ public Font getTextFont() {
+ return textFont;
+ }
+
+ public void setTextFont(final Font textFont) {
+ this.textFont = textFont;
+ }
+
+ public String getText() {
+ return text;
+ }
+
+ public void setText(final String text) {
+ this.text = text;
+ }
+
+ public String getImageName() {
+ return imageName;
+ }
+
+ public void setImageName(final String imageName) {
+ this.imageName = imageName;
+ }
+
+ public String getPressedImageName() {
+ return pressedImageName;
+ }
+
+ public void setPressedImageName(final String pressedImageName) {
+ this.pressedImageName = pressedImageName;
+ }
+
+ public java.awt.Image getImage() {
+ return image;
+ }
+
+ public void setImage(final java.awt.Image image) {
+ this.image = image;
+ }
+
+ public java.awt.Image getPressedImage() {
+ return pressedImage;
+ }
+
+ public void setPressedImage(final java.awt.Image pressedImage) {
+ this.pressedImage = pressedImage;
+ }
+}
=======================================
--- /dev/null
+++ /branches/SamKnows/src/skin/Image.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,52 @@
+package skin;
+
+import java.awt.*;
+import java.io.Serializable;
+
+public class Image implements Serializable {
+ private Rectangle rect;
+ private String imageName;
+ private java.awt.Image image;
+ private boolean visible;
+
+ public Image() {
+ }
+
+ public Image(final Rectangle rect, final String imageName, final boolean visible) {
+ this.rect = rect;
+ this.imageName = imageName;
+ this.visible = visible;
+ }
+
+ public Rectangle getRect() {
+ return rect;
+ }
+
+ public void setRect(final Rectangle rect) {
+ this.rect = rect;
+ }
+
+ public String getImageName() {
+ return imageName;
+ }
+
+ public void setImageName(final String imageName) {
+ this.imageName = imageName;
+ }
+
+ public java.awt.Image getImage() {
+ return image;
+ }
+
+ public void setImage(final java.awt.Image image) {
+ this.image = image;
+ }
+
+ public boolean isVisible() {
+ return visible;
+ }
+
+ public void setVisible(final boolean visible) {
+ this.visible = visible;
+ }
+}
=======================================
--- /dev/null
+++ /branches/SamKnows/src/skin/Interface.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,259 @@
+package skin;
+
+import javax.imageio.ImageIO;
+import java.beans.XMLDecoder;
+import java.beans.XMLEncoder;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.io.Serializable;
+
+public class Interface implements Serializable {
+
+ private static Interface iface;
+ private final static String fileName = "/META-INF/interface.xml";
+
+ private String preparingTestString;
+ private String firewallTestString;
+ private String uploadTestString;
+ private String downloadTestString;
+ private String completeTestString;
+ private String waitString;
+ private String stopString;
+
+ private Image mainBackgroundImage;
+ private Image background1Image;
+ private Image background2Image;
+ private Button startButton;
+ private Button stopButton;
+ private Button advancedButton;
+ private TextPane textPane;
+ private Arrow arrow1;
+ private Arrow arrow2;
+ private Label statusLabel;
+ private Label value1Label;
+ private Label value2Label;
+ private Label rttLabel;
+ private Label lossLabel;
+
+ public String getPreparingTestString() {
+ return preparingTestString;
+ }
+
+ public void setPreparingTestString(final String preparingTestString) {
+ this.preparingTestString = preparingTestString;
+ }
+
+ public String getFirewallTestString() {
+ return firewallTestString;
+ }
+
+ public void setFirewallTestString(final String firewallTestString) {
+ this.firewallTestString = firewallTestString;
+ }
+
+ public String getUploadTestString() {
+ return uploadTestString;
+ }
+
+ public void setUploadTestString(final String uploadTestString) {
+ this.uploadTestString = uploadTestString;
+ }
+
+ public String getDownloadTestString() {
+ return downloadTestString;
+ }
+
+ public void setDownloadTestString(final String downloadTestString) {
+ this.downloadTestString = downloadTestString;
+ }
+
+ public String getCompleteTestString() {
+ return completeTestString;
+ }
+
+ public void setCompleteTestString(final String completeTestString) {
+ this.completeTestString = completeTestString;
+ }
+
+ public String getWaitString() {
+ return waitString;
+ }
+
+ public void setWaitString(final String waitString) {
+ this.waitString = waitString;
+ }
+
+ public String getStopString() {
+ return stopString;
+ }
+
+ public void setStopString(final String stopString) {
+ this.stopString = stopString;
+ }
+
+ public Image getMainBackgroundImage() {
+ return mainBackgroundImage;
+ }
+
+ public void setMainBackgroundImage(final Image mainBackgroundImage) {
+ this.mainBackgroundImage = mainBackgroundImage;
+ }
+
+ public Image getBackground1Image() {
+ return background1Image;
+ }
+
+ public void setBackground1Image(final Image background1Image) {
+ this.background1Image = background1Image;
+ }
+
+ public Image getBackground2Image() {
+ return background2Image;
+ }
+
+ public void setBackground2Image(final Image background2Image) {
+ this.background2Image = background2Image;
+ }
+
+ public Button getStartButton() {
+ return startButton;
+ }
+
+ public void setStartButton(final Button startButton) {
+ this.startButton = startButton;
+ }
+
+ public Button getStopButton() {
+ return stopButton;
+ }
+
+ public void setStopButton(final Button stopButton) {
+ this.stopButton = stopButton;
+ }
+
+ public Button getAdvancedButton() {
+ return advancedButton;
+ }
+
+ public void setAdvancedButton(final Button advancedButton) {
+ this.advancedButton = advancedButton;
+ }
+
+ public TextPane getTextPane() {
+ return textPane;
+ }
+
+ public void setTextPane(final TextPane textPane) {
+ this.textPane = textPane;
+ }
+
+ public Arrow getArrow1() {
+ return arrow1;
+ }
+
+ public void setArrow1(final Arrow arrow1) {
+ this.arrow1 = arrow1;
+ }
+
+ public Arrow getArrow2() {
+ return arrow2;
+ }
+
+ public void setArrow2(final Arrow arrow2) {
+ this.arrow2 = arrow2;
+ }
+
+ public Label getStatusLabel() {
+ return statusLabel;
+ }
+
+ public void setStatusLabel(final Label statusLabel) {
+ this.statusLabel = statusLabel;
+ }
+
+ public Label getValue1Label() {
+ return value1Label;
+ }
+
+ public void setValue1Label(final Label value1Label) {
+ this.value1Label = value1Label;
+ }
+
+ public Label getValue2Label() {
+ return value2Label;
+ }
+
+ public void setValue2Label(final Label value2Label) {
+ this.value2Label = value2Label;
+ }
+
+ public Label getRttLabel() {
+ return rttLabel;
+ }
+
+ public void setRttLabel(final Label rttLabel) {
+ this.rttLabel = rttLabel;
+ }
+
+ public Label getLossLabel() {
+ return lossLabel;
+ }
+
+ public void setLossLabel(final Label lossLabel) {
+ this.lossLabel = lossLabel;
+ }
+
+ public void save(final String fileName) {
+ try {
+ final FileOutputStream fos = new FileOutputStream(fileName);
+ final XMLEncoder encoder = new XMLEncoder(fos);
+ encoder.writeObject(this);
+ encoder.close();
+ } catch (IOException ex) {
+ ex.printStackTrace();
+ }
+ }
+
+ public static Interface getInstance() {
+ if (iface == null) {
+ try {
+ final InputStream is = Interface.class.getResourceAsStream(fileName);
+ final XMLDecoder decoder = new XMLDecoder(is);
+ iface = (Interface) decoder.readObject();
+ decoder.close();
+
+ iface.startButton.setImage(loadImage(iface.startButton.getImageName()));
+ iface.startButton.setPressedImage(loadImage(iface.startButton.getPressedImageName()));
+ iface.stopButton.setImage(loadImage(iface.stopButton.getImageName()));
+ iface.stopButton.setPressedImage(loadImage(iface.stopButton.getPressedImageName()));
+ iface.advancedButton.setImage(loadImage(iface.advancedButton.getImageName()));
+ iface.advancedButton.setPressedImage(loadImage(iface.advancedButton.getPressedImageName()));
+
+ iface.mainBackgroundImage.setImage(loadImage(iface.mainBackgroundImage.getImageName()));
+ if (iface.background1Image != null && iface.background1Image.isVisible())
+ iface.background1Image.setImage(loadImage(iface.background1Image.getImageName()));
+ if (iface.background2Image != null && iface.background2Image.isVisible())
+ iface.background2Image.setImage(loadImage(iface.background2Image.getImageName()));
+ if (iface.arrow1 != null && iface.arrow1.isVisible())
+ iface.arrow1.setArrowImage(loadImage(iface.arrow1.getArrowImageName()));
+ if (iface.arrow2 != null && iface.arrow2.isVisible())
+ iface.arrow2.setArrowImage(loadImage(iface.arrow2.getArrowImageName()));
+ } catch (IOException ex) {
+ ex.printStackTrace();
+ }
+ }
+ return iface;
+ }
+
+ private static java.awt.Image loadImage(final String path) throws IOException {
+ java.awt.Image img = null;
+ final InputStream in = Interface.class.getClassLoader().getResourceAsStream(path);
+ if (in != null) {
+ img = ImageIO.read(in);
+ in.close();
+ }
+ return img;
+ }
+
+}
=======================================
--- /dev/null
+++ /branches/SamKnows/src/skin/Label.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,63 @@
+package skin;
+
+import java.awt.*;
+import java.io.Serializable;
+
+public class Label implements Serializable {
+ private Rectangle rect;
+ private Color textColor;
+ private Font textFont;
+ private int horizontalAlignment;
+ private boolean visible;
+
+ public Label() {
+ }
+
+ public Label(final Rectangle rect, final Color textColor, final Font textFont, final int horizontalAlignment, final boolean visible) {
+ this.rect = rect;
+ this.textColor = textColor;
+ this.textFont = textFont;
+ this.horizontalAlignment = horizontalAlignment;
+ this.visible = visible;
+ }
+
+ public Rectangle getRect() {
+ return rect;
+ }
+
+ public void setRect(final Rectangle rect) {
+ this.rect = rect;
+ }
+
+ public Color getTextColor() {
+ return textColor;
+ }
+
+ public void setTextColor(final Color textColor) {
+ this.textColor = textColor;
+ }
+
+ public Font getTextFont() {
+ return textFont;
+ }
+
+ public void setTextFont(final Font textFont) {
+ this.textFont = textFont;
+ }
+
+ public int getHorizontalAlignment() {
+ return horizontalAlignment;
+ }
+
+ public void setHorizontalAlignment(final int horizontalAlignment) {
+ this.horizontalAlignment = horizontalAlignment;
+ }
+
+ public boolean isVisible() {
+ return visible;
+ }
+
+ public void setVisible(final boolean visible) {
+ this.visible = visible;
+ }
+}
=======================================
--- /dev/null
+++ /branches/SamKnows/src/skin/TextPane.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,46 @@
+package skin;
+
+import java.io.Serializable;
+
+public class TextPane implements Serializable {
+ private int x;
+ private int y;
+ private int w;
+ private int h;
+
+ public TextPane() {
+ }
+
+ public int getX() {
+ return x;
+ }
+
+ public void setX(final int x) {
+ this.x = x;
+ }
+
+ public int getY() {
+ return y;
+ }
+
+ public void setY(final int y) {
+ this.y = y;
+ }
+
+ public int getW() {
+ return w;
+ }
+
+ public void setW(final int w) {
+ this.w = w;
+ }
+
+ public int getH() {
+ return h;
+ }
+
+ public void setH(final int h) {
+ this.h = h;
+ }
+
+}
=======================================
--- /dev/null
+++ /branches/SamKnows/src/skin/control/SkinArrow.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,111 @@
+package skin.control;
+
+import skin.Arrow;
+
+import javax.swing.*;
+import java.awt.*;
+import java.awt.geom.AffineTransform;
+import java.awt.image.AffineTransformOp;
+import java.awt.image.BufferedImage;
+import java.awt.image.BufferedImageOp;
+
+public class SkinArrow {
+
+ private Arrow skin;
+
+ private int value = 0;
+
+ private double firstAngle;
+ private double intervalAngle;
+ private double[] angles;
+ private MoveArrow task = null;
+
+ private JPanel parent;
+
+ public SkinArrow(final JPanel parent, final Arrow skin) {
+ this.parent = parent;
+ this.skin = skin;
+
+ firstAngle = Math.toRadians(skin.getFirstAngle());
+ final double lastAngle = Math.toRadians(skin.getLastAngle());
+ intervalAngle = (lastAngle - firstAngle) / (skin.getScales().length - 1);
+
+ angles = new double[skin.getScales().length];
+ for (int i = 1; i < skin.getScales().length; i++) {
+ angles[i] = angles[i - 1] + intervalAngle;
+ }
+ }
+
+ protected class MoveArrow extends SwingWorker<Exception, String> {
+ int newValue;
+ int count;
+ int interval;
+
+ public MoveArrow(final int oldValue, final int newValue) {
+ value = oldValue;
+ this.newValue = newValue;
+ interval = (newValue - oldValue) / 10;
+ count = 0;
+ }
+
+ protected Exception doInBackground() throws Exception {
+ while (count < 10) {
+ value += interval;
+ parent.repaint();
+ count++;
+ Thread.sleep(500 / 10);
+ }
+ if (value != newValue) {
+ value = newValue;
+ parent.repaint();
+ }
+ return null;
+ }
+ }
+
+ public void setValue(final int value) {
+ if (value >= 0 && value <= skin.getScales()[skin.getScales().length - 1]) {
+ if (task != null) {
+ task.cancel(true);
+ task = null;
+ }
+ if (Math.abs(this.value - value) > 200) {
+ task = new MoveArrow(this.value, value);
+ task.execute();
+ } else {
+ this.value = value;
+ parent.repaint();
+ }
+ }
+ }
+
+ private double getAngle() {
+ double value1 = value;
+ double firstAngle1 = firstAngle;
+ for (int i = 1; i < skin.getScales().length; i++) {
+ if (value <= skin.getScales()[i]) {
+ firstAngle1 = firstAngle + angles[i - 1];
+ value1 = (value - skin.getScales()[i - 1]) * intervalAngle / (skin.getScales()[i] - skin.getScales()[i - 1]);
+ break;
+ }
+ }
+ return value1 + firstAngle1;
+ }
+
+ // draw arrow
+ public void drawArrow(final Graphics g) {
+ final double angle = getAngle();
+
+ final Graphics2D g2d = (Graphics2D) g;
+ final AffineTransform origXform = g2d.getTransform();
+ final AffineTransform newXform = (AffineTransform) origXform.clone();
+ //center of rotation is center of the panel
+ newXform.rotate(angle, skin.getArrowX(), skin.getArrowY());
+ g2d.setTransform(newXform);
+ //draw image centered in panel
+ final BufferedImageOp bio = new AffineTransformOp(new AffineTransform(), AffineTransformOp.TYPE_BILINEAR);
+ g2d.drawImage((BufferedImage) skin.getArrowImage(), bio, skin.getArrowX() - skin.getArrowAnchorX(), skin.getArrowY() - skin.getArrowAnchorY());
+ g2d.setTransform(origXform);
+ }
+
+}
=======================================
--- /dev/null
+++ /branches/SamKnows/src/skin/control/SkinButton.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,47 @@
+package skin.control;
+
+import skin.Button;
+
+import javax.swing.*;
+import java.awt.*;
+
+public class SkinButton extends JButton {
+
+ private Button skin;
+
+ public SkinButton(final Button skin, final Insets insets) {
+ super();
+
+ this.skin = skin;
+
+ setDoubleBuffered(true);
+ setContentAreaFilled(false);
+ setBorderPainted(false);
+ setFocusPainted(false);
+ setOpaque(false);
+
+ final Dimension size = new Dimension(skin.getRect().width, skin.getRect().height);
+ setPreferredSize(size);
+ setBounds(skin.getRect().x + insets.left, skin.getRect().y + insets.top, size.width, size.height);
+ }
+
+ @Override
+ protected void paintComponent(final Graphics g) {
+ super.paintComponent(g);
+
+ if (model.isPressed())
+ g.drawImage(skin.getPressedImage(), 0, 0, null);
+ else
+ g.drawImage(skin.getImage(), 0, 0, null);
+
+ if (skin.getText() != null) {
+ g.setColor(skin.getTextColor());
+ g.setFont(skin.getTextFont());
+ final String sValue = skin.getText();
+ final FontMetrics fm = g.getFontMetrics();
+ final int baseline = fm.getMaxAscent() + (getBounds().height - (fm.getAscent() + fm.getMaxDescent())) / 2;
+ g.drawString(sValue, (getBounds().width - g.getFontMetrics().stringWidth(sValue)) / 2, baseline);
+ }
+ }
+
+}
=======================================
--- /dev/null
+++ /branches/SamKnows/src/skin/control/SkinLabel.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,31 @@
+package skin.control;
+
+import skin.Label;
+
+import javax.swing.*;
+import java.awt.*;
+
+
+public class SkinLabel extends JLabel {
+
+// LEFT SwingConstants.LEFT
+// CENTER SwingConstants.CENTER
+
+ // RIGHT SwingConstants.RIGHT
+// LEADING SwingConstants.LEADING
+// TRAILING SwingConstants.TRAILING
+ public SkinLabel(final Label skin, final Insets insets) {
+ super();
+
+ final Dimension size = new Dimension(skin.getRect().width, skin.getRect().height);
+ setPreferredSize(size);
+ setBounds(skin.getRect().x + insets.left, skin.getRect().y + insets.top,
+ size.width, size.height);
+
+ setForeground(skin.getTextColor());
+ setFont(skin.getTextFont());
+ setVisible(skin.isVisible());
+ setHorizontalAlignment(skin.getHorizontalAlignment());
+ }
+
+}
=======================================
--- /dev/null
+++ /branches/SamKnows/src/skin/control/SkinPanel.java Tue Jun 1 09:44:58 2010
@@ -0,0 +1,148 @@
+package skin.control;
+
+import skin.Interface;
+
+import javax.swing.*;
+import java.awt.*;
+
+public class SkinPanel extends JPanel {
+
+ private Interface skin;
+
+ private SkinLabel statusLabel;
+ private SkinButton startButton;
+ private SkinButton stopButton;
+ private SkinButton advancedButton;
+ private SkinLabel value1Label;
+ private SkinLabel value2Label;
+ private SkinLabel rttLabel;
+ private SkinLabel lossLabel;
+ private SkinArrow arrow1;
+ private SkinArrow arrow2;
+
+ public SkinPanel(final Interface skin) {
+ super();
+ this.skin = skin;
+ setLayout(null);
+
+ setDoubleBuffered(true);
+ setOpaque(false);
+
+ Insets insets = getInsets();
+
+ statusLabel = new SkinLabel(skin.getStatusLabel(), insets);
+ add(statusLabel);
+
+ startButton = new SkinButton(skin.getStartButton(), insets);
+ add(startButton);
+ stopButton = new SkinButton(skin.getStopButton(), insets);
+ add(stopButton);
+ advancedButton = new SkinButton(skin.getAdvancedButton(), insets);
+ add(advancedButton);
+
+ value1Label = new SkinLabel(skin.getValue1Label(), insets);
+ add(value1Label);
+ if (skin.getValue2Label() != null && skin.getValue2Label().isVisible()) {
+ value2Label = new SkinLabel(skin.getValue2Label(), insets);
+ add(value2Label);
+ }
+ rttLabel = new SkinLabel(skin.getRttLabel(), insets);
+ add(rttLabel);
+ lossLabel = new SkinLabel(skin.getLossLabel(), insets);
+ add(lossLabel);
+
+ arrow1 = new SkinArrow(this, skin.getArrow1());
+ if (skin.getArrow2() != null && skin.getArrow2().isVisible())
+ arrow2 = new SkinArrow(this, skin.getArrow2());
+
+ }
+
+ protected void paintComponent(final Graphics g) {
+ if (skin.getMainBackgroundImage().isVisible()) {
+ g.drawImage(skin.getMainBackgroundImage().getImage(),
+ skin.getMainBackgroundImage().getRect().x,
+ skin.getMainBackgroundImage().getRect().y,
+ skin.getMainBackgroundImage().getRect().width,
+ skin.getMainBackgroundImage().getRect().height,
+ null);
+ }
+ if (skin.getBackground1Image() != null && skin.getBackground1Image().isVisible()) {
+ g.drawImage(skin.getBackground1Image().getImage(),
+ skin.getBackground1Image().getRect().x,
+ skin.getBackground1Image().getRect().y,
+ skin.getBackground1Image().getRect().width,
+ skin.getBackground1Image().getRect().height,
+ null);
+ }
+ if (skin.getBackground2Image() != null && skin.getBackground2Image().isVisible()) {
+ g.drawImage(skin.getBackground2Image().getImage(),
+ skin.getBackground2Image().getRect().x,
+ skin.getBackground2Image().getRect().y,
+ skin.getBackground2Image().getRect().width,
+ skin.getBackground2Image().getRect().height,
+ null);
+ }
+ arrow1.drawArrow(g);
+ if (skin.getArrow2() != null && skin.getArrow2().isVisible())
+ arrow2.drawArrow(g);
+ }
+
+ public void setValue1(final int value) {
+ if (value > 100000)
+ return;
+ value1Label.setText(String.format("%.2f", value / 1000.0) + " Mb/s");
+ arrow1.setValue(value);
+ }
+
+ public void setValue1_(final int value) {
+ if (value > 100000)
+ return;
+ arrow1.setValue(value);
+ }
+
+ public void setValue2(final int value) {
+ if (value > 100000)
+ return;
+ if (skin.getValue2Label() != null && skin.getValue2Label().isVisible())
+ value2Label.setText(String.format("%.2f", value / 1000.0) + " Mb/s");
+ else
+ value1Label.setText(String.format("%.2f", value / 1000.0) + " Mb/s");
+ if (skin.getArrow2() != null && skin.getArrow2().isVisible())
+ arrow2.setValue(value);
+ else
+ arrow1.setValue(value);
+ }
+
+ public void setValue2_(final int value) {
+ if (value > 100000)
+ return;
+ if (skin.getArrow2() != null && skin.getArrow2().isVisible())
+ arrow2.setValue(value);
+ else
+ arrow1.setValue(value);
+ }
+
+ public void setRtt(final double value) {
+ rttLabel.setText(String.format("%.2f", value));
+ }
+
+ public void setLoss(final double value) {
+ lossLabel.setText(String.format("%.2f", value * 100));
+ }
+
+ public SkinLabel getStatusLabel() {
+ return statusLabel;
+ }
+
+ public SkinButton getStartButton() {
+ return startButton;
+ }
+
+ public SkinButton getStopButton() {
+ return stopButton;
+ }
+
+ public SkinButton getAdvancedButton() {
+ return advancedButton;
+ }
+}


  • [ndt] r359 committed - SamKnows Branch, ndt, 06/01/2010

Archive powered by MHonArc 2.6.16.

Top of Page