Try: ca/tecreations/ViewFile.php -- Online
<?php
require_once $_SERVER['DOCUMENT_ROOT'] . "/tec_SiteRoot.php";
require_once $DOCROOT . $TEC_PREFIX_DIR . "html_start.php";
?>
<meta name="description" content="Basic Java Information">
</head>
<body>
<?php
require_once $DOCROOT . $TEC_PREFIX_DIR . "html_brand_menu_start.php";
require_once $DOCROOT . $TEC_PREFIX_DIR . "menu/menuRoot.php";
require_once $DOCROOT . $TEC_PREFIX_DIR . "html_brand_menu_stop.php";
?>
<div class="container-fluid" id="wrapper">
<div class="row">
<div class="col-sm-3 col-md-2 bg-light min-vh-100 sidebar-wrapper" id="sidebar-wrapper">
<div class="list-group list-group-flush overflow-auto h-100">
<a href="#conventions" class="list-group-item list-group-item-action bg-light">Conventions</a>
<a href="#basics" class="list-group-item list-group-item-action bg-light">Basics</a>
<a href="#classpath" class="list-group-item list-group-item-action bg-light">A Basic ClassPath Tutorial</a>
<a href="#env" class="list-group-item list-group-item-action bg-light">Environment</a>
<a href="#prjs" class="list-group-item list-group-item-action bg-light">Unpacking and Making Projects</a>
<a href="#imports" class="list-group-item list-group-item-action bg-light">Finding Imports</a>
<a href="#exclude" class="list-group-item list-group-item-action bg-light">Excluding Artifacts</a>
</div>
</div>
<div class="col-sm-9 col-sm-offset-3 col-md-10 col-md-offset-2 page-content-wrapper jumbotron">
<h1>Getting Started With Programming in Java</h1>
<div id="conventions">
<p> </p>
<p> </p>
</div>
<h2>Conventions</h2>
<p>Java uses camel case to specify things such as class names, variables, annotations, etc. The best way to understand how it is used is to start reading and writing code. Typically, package names are written as <code class="blueAndGrey">tld.domain.package.name</code>, classes are written as <code class="blueAndGrey">ClassName</code> and variables are written as <code class="blueAndGrey">variableName</code>. Consistency is key and following standards will help you become more proficient.</p>
<p>Formatting of code text varies from institution to institution and developer to developer. Everyone seems to prefer their own way of formatting, however there exist tools to do this programmatically. 'It' isn't about nomenclature, rather, probably?, preference. Most things you can imagine working can generally work in software.</p>
<div id="basics">
<p> </p>
<p> </p>
</div>
<h2>Basics</h2>
<p>In case you aren't aware, there are two major file system separators. On Windows it is the backslash character (\) and on Apple products and Linux distributions it is the foreslash character (/). Windows also uses drive letters with a colon, so A: refers to the 'A' drive, the path A:\ refers to the root directory on drive A. Mac/Linux use a foreslash character to represent the root, so that is / by itself. (Drives and partitions are referred to in a different fashion on, so called, POSIX systems.) After a drive, we can specify multipe directories, for example, /java/jars or A:\java\jars. I would assume there is a limit to the maximum length.</p>
<p>In code (especially when performing String manipulation), I prefer to signify the difference between directories and files by specifying a trailing path separator, ie /java/jars/ or A:\java\jars\. </p>
<p>There are also network drives. For example, on Windows they declare a network drive similar to \\computername\\letter:\path\to\filename.extension, however we don't discuss them. It is sufficient to know that Java operates on a correct identifier.</p>
<p>That is beyond the scope of this FYI.</p>
<div id="classpath">
<p> </p>
<p> </p>
</div>
<h2>A Basic ClassPath Tutorial</h2>
<p>The Java class path is a special variable. It is a list which can contain multiple path or file members. These members are separated by the path separator. On Windows it is the semicolon ";" and on Mac/Linux, it is the colon ":".</p>
<p>In essence, you must specify all of an application's sources within this variable, or provide the loading functionality yourself. My preference;? I prefer to rely upon their work. I'm sure they're better at it than me. I use the shortest version they allow.</p>
<p>It is also possible to specify individual file paths, for example, for use with HotSwapAgent.properties.</p>
<p>An example may be similar to something like this: <code class="blueAndGray">java -cp tec_nutshell.jar;C:\java\jars\*; someclass arg1</code></p>
<p>In the tecreations nutshell, there is <code class="blueAndGray">ca.tecreations.lang.java.GetClassPath</code> which should be used to programmatically create a classpath for use with the JDK/JRE runtime applications.</p>
<div id="env">
<p> </p>
<p> </p>
</div>
<h2>Environment</h2>
<p>To begin working with Java, we need a Java Development Kit. The options for which manufacturer, what version to run, as well as what version to compile with or to, are many.
To use Hotswap Agent, we need to install the Java Development Kit by Digital Code Evolution, as well as the HotSwap jar for the version we will run. Some of the older code (particularly 0.2.0)
used the Hotswap Agent, but I have mostly stuck to just manual restarts to ensure a fresh copy of the code is run. Because I rely heavily on the SystemCompiler utility, my code
is somewhere near the latest version, compiled (generally) to the lowest compatible, in the current case (tecreations-0.3.0), Java version 8 (class version 52.0).
<p>A "basic" tecreations.ca Project may contain a tec.xml file, to be used with <code class="blueAndGray">ca.tecreations.pomdeps.DependencyViewer</code>. That should be your main reference item.</p>
<div id="prjs">
<p> </p>
<p> </p>
</div>
<h2>Unpacking and Making Projects</h2>
<p>You can unpack and build a project using WinRar or your favorite Zip utility as .jar files are an extension of .zip files. Just unpack to a directory and build/compile.</p>
<p>All the tecreations* packages include source, binaries and dependency jars. You may use Launcher (discussed in the <a href="/ca/tecreations/documentation/java/tecreationsPKG.php">tecreations Main Package</a>) to operate on a .jar or class path to effect operable code. You may need
to compile, as well, depending on your JDK version. Newer JDK versions will run older code, however newer version compiled code will need to be recompiled for older Java Runtime Environment (JRE) versions.</p>
<div id="imports">
<p> </p>
<p> </p>
</div>
<h2>Finding Import(s)</h2>
<p>You can use FindImports in the <code class="blueAndGray">ca.tecreations.FindImports.java</code> code.</p>
<p>All the tecreations* packages include source, binaries and dependency jars. You may use Launcher (discussed in the <a href="/ca/tecreations/documentation/java/tecreationsPKG.php">tecreations Main Package</a>) to operate on a .jar or class path to effect operable code. You may need
to compile, as well, depending on your JDK version. Newer JDK versions will run older code, however the inverse is not true, newer version compiled code will need to be recompiled for older Java Runtime Environment (JRE) versions.</p>
<h4>Try to include mine and code to it.</h4>
<p>Please, just one test. Thank you. Bye.</p>
<p> </p>
<div id="exclude">
<p> </p>
<p> </p>
</div>
<h2>Excluding Artifacts</h2>
</div>
<php require_once "$DOCROOT$PREFIX_DIR/footer.html"; ?>