diff --git a/out/DIRECTORY_LISTING b/out/DIRECTORY_LISTING index 8807b97..23c9d7e 100644 --- a/out/DIRECTORY_LISTING +++ b/out/DIRECTORY_LISTING @@ -17,14 +17,14 @@
-

Directory Listing for /

📁.. (Previous Directory)
🗎reset.css 2022-07-24T00:27:54.916308747Z niconiconii 1093
-
📁articles 2022-07-24T00:27:55.628296037Z niconiconii 4096
-
🗎uploadform.html 2022-07-24T00:27:55.568297107Z niconiconii 884
-
🗎sig.css 2022-07-24T00:27:55.564297179Z niconiconii 6238
-
🗎testfile.html 2022-07-24T00:27:55.568297107Z niconiconii 804
-
🗎otherpage.html 2022-07-24T00:27:55.576296965Z niconiconii 70355
-
📁images 2022-07-24T00:27:55.624296107Z niconiconii 4096
-
🗎codeBackground 2022-07-24T00:27:55.568297107Z niconiconii 2635
+

Directory Listing for /

📁.. (Previous Directory)
📁articles 2022-07-26T15:21:39.694961518Z codespace 4096
+
📁images 2022-07-26T15:21:39.690961447Z codespace 4096
+
🗎uploadform.html 2022-07-26T15:21:39.618960169Z codespace 884
+
🗎codeBackground 2022-07-26T15:21:39.594959742Z codespace 2635
+
🗎otherpage.html 2022-07-26T15:21:39.598959813Z codespace 941
+
🗎reset.css 2022-07-26T15:21:39.598959813Z codespace 1093
+
🗎sig.css 2022-07-26T15:21:39.614960098Z codespace 6238
+
🗎testfile.html 2022-07-26T15:21:39.626960311Z codespace 804
diff --git a/out/articles/DIRECTORY_LISTING b/out/articles/DIRECTORY_LISTING index a26eaa7..41bfcf9 100644 --- a/out/articles/DIRECTORY_LISTING +++ b/out/articles/DIRECTORY_LISTING @@ -17,13 +17,13 @@
-

Directory Listing for /articles/

📁.. (Previous Directory)
🗎sigplace1.article 2022-07-24T00:27:55.552297393Z niconiconii 65060
-
🗎Love Live! Custom Arcade Controller.article.html 2022-07-24T00:27:55.616296251Z niconiconii 1214
-
🗎sigplace1.article.html 2022-07-24T00:27:55.604296465Z niconiconii 65777
-
🗎curabitur vel tempus ex.article 2022-07-24T00:27:55.556297321Z niconiconii 734
-
📁test articles 2022-07-24T00:27:55.612296322Z niconiconii 4096
-
🗎curabitur vel tempus ex.article.html 2022-07-24T00:27:55.604296465Z niconiconii 1451
-
🗎Love Live! Custom Arcade Controller.article 2022-07-24T00:27:55.560297251Z niconiconii 497
+

Directory Listing for /articles/

📁.. (Previous Directory)
🗎Love Live! Custom Arcade Controller.article.html 2022-07-26T15:21:39.626960311Z codespace 1214
+
🗎Love Live! Custom Arcade Controller.article 2022-07-26T15:21:39.03894987Z codespace 497
+
🗎sigplace1.article.html 2022-07-26T15:21:39.678961234Z codespace 74556
+
🗎curabitur vel tempus ex.article 2022-07-26T15:21:39.054950154Z codespace 734
+
📁test articles 2022-07-26T15:21:39.646960666Z codespace 4096
+
🗎curabitur vel tempus ex.article.html 2022-07-26T15:21:39.638960524Z codespace 1451
+
🗎sigplace1.article 2022-07-26T15:21:39.590959671Z codespace 73839
diff --git a/out/articles/curabitur vel tempus ex.article b/out/articles/curabitur vel tempus ex.article index 10d06aa..063ee1a 100644 --- a/out/articles/curabitur vel tempus ex.article +++ b/out/articles/curabitur vel tempus ex.article @@ -1,11 +1,11 @@

Curabitur vel tempus ex

-

+

Curabitur vel tempus ex. Duis cursus sapien nisl, ut pulvinar dui porttitor ut. Nullam odio purus, tristique non turpis sit amet, malesuada ultricies purus. Mauris ut nulla nisl. Aenean sit amet est egestas justo volutpat consequat. Suspendisse in sagittis augue, et mattis tortor. Nullam viverra metus et nibh fringilla iaculis.


-

+

 <><Test>"</test></test2><test3>"
             
diff --git a/out/articles/curabitur vel tempus ex.article.html b/out/articles/curabitur vel tempus ex.article.html index e35900a..e94590b 100644 --- a/out/articles/curabitur vel tempus ex.article.html +++ b/out/articles/curabitur vel tempus ex.article.html @@ -18,13 +18,13 @@

Curabitur vel tempus ex

-

+

Curabitur vel tempus ex. Duis cursus sapien nisl, ut pulvinar dui porttitor ut. Nullam odio purus, tristique non turpis sit amet, malesuada ultricies purus. Mauris ut nulla nisl. Aenean sit amet est egestas justo volutpat consequat. Suspendisse in sagittis augue, et mattis tortor. Nullam viverra metus et nibh fringilla iaculis.


-

+

 <><Test>"</test></test2><test3>"
             
diff --git a/out/articles/sigplace1.article b/out/articles/sigplace1.article index d63a232..e4e49a0 100644 --- a/out/articles/sigplace1.article +++ b/out/articles/sigplace1.article @@ -1,35 +1,35 @@

Welcome to SigPlace!

-

+

This is a SigPlace article! It will contain information that is important (probably) and will be layed out as such.

-

+

Paragraphs are automatically split up for readability and generated correctly via the parser. There's quite a bit of flexibility with the system and makes it easy to post updates should they be required.

-

+

A lot of content management systems would do this by having a web interface and submitting content and managing it that way, but by coding my own management system and using the built-in OS' filesystem to handle the work, I save myself a lot of pains and headaches.

-

+

Lorem ipsum dolor sit amet, consectetur adipiscing elit. In feugiat, urna ut sollicitudin luctus, nulla magna faucibus mauris, at semper nisl nisi ut mauris. Vestibulum cursus tortor velit, ut congue ex porta in. Nullam hendrerit risus sit amet neque euismod faucibus. Sed ac diam non lectus euismod pulvinar eu non mauris. Donec accumsan nisl efficitur, sodales lectus et, finibus quam. Sed vel consectetur leo. Cras ut condimentum quam. Aliquam molestie viverra congue. Donec scelerisque nibh ac nulla dictum semper. Aliquam id massa a massa bibendum finibus id ac sapien. Integer vitae ullamcorper enim, non semper massa.


-

+

Proin cursus sodales elit, vitae volutpat mi fermentum a. In vitae magna quis leo cursus accumsan id facilisis purus. Vestibulum accumsan iaculis turpis eu sollicitudin. Sed ultricies felis non elit suscipit interdum. Maecenas sollicitudin turpis justo, vel pretium sapien scelerisque eget. Nullam sagittis finibus risus ut aliquam. Praesent quam orci, dapibus ut ex ac, sodales dapibus nunc.


-

+

Fusce magna risus, iaculis non justo sit amet, semper sodales urna. Morbi eu eros lectus. Integer euismod venenatis eros a hendrerit. Nulla ultricies lectus nec quam condimentum fermentum. Quisque a turpis vitae orci pharetra ullamcorper. Nunc fringilla vitae nunc a aliquam. In aliquam gravida massa. Sed imperdiet dignissim sapien, ullamcorper rutrum lacus convallis ut.


-

+

Nunc tortor sem, dapibus mattis varius id, varius eu leo. Phasellus efficitur nulla a diam faucibus, id facilisis lacus malesuada. Nulla condimentum egestas erat a fermentum. Ut interdum dui id est condimentum, vel fermentum nisi ornare. Sed eu rhoncus magna, sit amet finibus eros. In a nibh tincidunt, suscipit tellus eleifend, faucibus mauris. Vestibulum sagittis nisi et efficitur ullamcorper. Donec sodales efficitur ligula id congue. Etiam egestas tristique interdum. Mauris at massa eget metus pellentesque fermentum nec non lacus. Nulla turpis nunc, feugiat vel euismod ac, maximus id est. Praesent cursus elit ac dolor hendrerit lacinia.


-

+

Vestibulum laoreet lorem consequat, mollis augue finibus, luctus libero. Praesent convallis sed velit vitae molestie. Vestibulum nec fringilla tellus, non dictum nulla. Donec tempor ac diam sit amet porta. Quisque mi ex, vulputate ac tincidunt vel, vestibulum vitae orci. Duis gravida mauris eget mauris pulvinar, lobortis tincidunt neque efficitur. Nunc blandit metus vitae faucibus vulputate. Curabitur rhoncus volutpat lorem, sit amet pulvinar ipsum. Fusce ultricies enim odio, a viverra quam tincidunt quis. Aliquam sollicitudin a sapien id efficitur. Proin at finibus elit, id gravida elit. Nulla facilisi. Ut tincidunt, ligula eu pulvinar dapibus, lorem nisl facilisis tellus, in ornare quam dolor quis libero. Pellentesque ut convallis orci. Donec volutpat nunc velit, tristique convallis purus lacinia sit amet. Maecenas porttitor cursus nisl sed porta.


Hello there! You can see this is the Love Live logo indeed! It is quite smol right now but that's okay. Let's keep on going with the text. If the caption is really long and with commas, they will now be combined,,,,,see how that works? Amazing!
-

+

Here we demonstrate the love live logo. But wait, it's literally like in the middle wtf is going on.Here we demonstrate the love live logo. But wait, it's literally like in the middle wtf is going on.Here we demonstrate the love live logo. But wait, it's literally like in the middle wtf is going on.


@@ -496,7 +496,7 @@ Here we demonstrate the love live logo. But wait, it's literally like in the mid -

+

 import java.io.IOException;
 import java.nio.charset.Charset;
@@ -622,322 +622,322 @@ Here we demonstrate the love live logo. But wait, it's literally like in the mid
                                 String endText=s.substring(s.indexOf("</pre>")+"</pre>".length(),s.length());
                                 s="";
                                 for (int j=0;j<storedCodeBlock.length();j++) {
-                                    if (storedCodeBlock.charAt(j)=='"') {
-                                        inString=!inString;
-                                        if (inString) {
-                                            s+=SPAN("")+"\"";
-                                        } else {
-                                            s+="\"</span>";
-                                            startPos=j+1;
+                                    if (storedCodeBlock.charAt(j)==""") {
+                                        inString=!inString;
+                                        if (inString) {
+                                            s+=SPAN("string")+"\"";
+                                        } else {
+                                            s+="\"</span>";
+                                            startPos=j+1;
                                         }
                                     } else
-                                    if (!inString&&!inChar) {
-                                        if (canBeNumericalConstant&&validNumericalConstantCharacters(lengthOfConstant, j)) {
+                                    if (!inString&&!inChar) {
+                                        if (canBeNumericalConstant&&validNumericalConstantCharacters(lengthOfConstant, j)) {
                                             lengthOfConstant++;
-                                            System.out.println("Length of Constant now "+lengthOfConstant);
+                                            System.out.println("Length of Constant now "+lengthOfConstant);
                                         }
-                                        if (canBeNumericalConstant&&lengthOfConstant>0&&!(validNumericalConstantCharacters(lengthOfConstant, j))) {
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            //System.out.println("Setting "+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j));
-                                            lengthOfConstant=0;
-                                            canBeNumericalConstant=false;
-                                            startPos=j+1;
+                                        if (canBeNumericalConstant&&lengthOfConstant>0&&!(validNumericalConstantCharacters(lengthOfConstant, j))) {
+                                            s+=SPAN("number")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
+                                            //System.out.println("Setting "+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j));
+                                            lengthOfConstant=0;
+                                            canBeNumericalConstant=false;
+                                            startPos=j+1;
                                         } else
-                                        if (!canBeNumericalConstant&&storedCodeBlock.charAt(j)=='.') {
-                                            //Previous section was a member.
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else 
-                                        if (j>3&&storedCodeBlock.substring(j-3,j+1).equals("true")&&!isAlphanumeric(j-4)&&!isAlphanumeric(j+1)) {
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j)+"</span>";
-                                            startPos=j+1;
-                                        } else 
-                                        if (j>4&&storedCodeBlock.substring(j-4,j+1).equals("false")&&!isAlphanumeric(j-5)&&!isAlphanumeric(j+1)) {
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j)+"</span>";
-                                            startPos=j+1;
-                                        } else 
-                                        if (storedCodeBlock.charAt(j)=='(') {
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else 
-                                        if (j>0&&isAlphanumeric(j-1) && storedCodeBlock.charAt(j)==' '&&storedCodeBlock.charAt(j-1)!=' ') {
-                                            //Previous section was a keyword.
-                                            keyword=true;
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else 
-                                        if (j>0&&isAlphanumeric(j-1) && (storedCodeBlock.charAt(j)==';'||storedCodeBlock.charAt(j)==':')) {
-                                            //Previous section was a keyword.
-                                            //keyword=true;
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else 
-                                        if (keyword&&!(storedCodeBlock.charAt(j)>='0'&&storedCodeBlock.charAt(j)<='9'||storedCodeBlock.charAt(j)>='A'&&storedCodeBlock.charAt(j)<='Z'||storedCodeBlock.charAt(j)>='a'&&storedCodeBlock.charAt(j)<='z'||storedCodeBlock.charAt(j)==' ')) {
-                                            keyword=false;
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
+                                        if (!canBeNumericalConstant&&storedCodeBlock.charAt(j)==".") {
+                                            //Previous section was a member.
+                                            s+=SPAN("class")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
+                                            startPos=j+1;
+                                        } else 
+                                        if (j>3&&storedCodeBlock.substring(j-3,j+1).equals("true")&&!isAlphanumeric(j-4)&&!isAlphanumeric(j+1)) {
+                                            s+=SPAN("number")+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j)+"</span>";
+                                            startPos=j+1;
+                                        } else 
+                                        if (j>4&&storedCodeBlock.substring(j-4,j+1).equals("false")&&!isAlphanumeric(j-5)&&!isAlphanumeric(j+1)) {
+                                            s+=SPAN("number")+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j)+"</span>";
+                                            startPos=j+1;
+                                        } else 
+                                        if (storedCodeBlock.charAt(j)=="(") {
+                                            s+=SPAN("function")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
+                                            startPos=j+1;
+                                        } else 
+                                        if (j>0&&isAlphanumeric(j-1) && storedCodeBlock.charAt(j)==" "&&storedCodeBlock.charAt(j-1)!=" ") {
+                                            //Previous section was a keyword.
+                                            keyword=true;
+                                            s+=SPAN("keyword")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
+                                            startPos=j+1;
+                                        } else 
+                                        if (j>0&&isAlphanumeric(j-1) && (storedCodeBlock.charAt(j)==";"||storedCodeBlock.charAt(j)==":")) {
+                                            //Previous section was a keyword.
+                                            //keyword=true;
+                                            s+=SPAN("keyword")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
+                                            startPos=j+1;
+                                        } else 
+                                        if (keyword&&!(storedCodeBlock.charAt(j)>="0"&&storedCodeBlock.charAt(j)<="9"||storedCodeBlock.charAt(j)>="A"&&storedCodeBlock.charAt(j)<="Z"||storedCodeBlock.charAt(j)>="a"&&storedCodeBlock.charAt(j)<="z"||storedCodeBlock.charAt(j)==" ")) {
+                                            keyword=false;
+                                            s+=SPAN("variable")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
+                                            startPos=j+1;
                                         } else
-                                        if (!isAlphanumeric(j)){
-                                            if (startPos<j) {
-                                                s+=storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j);
-                                            } else {
-                                                s+=storedCodeBlock.charAt(j);
+                                        if (!isAlphanumeric(j)){
+                                            if (startPos<j) {
+                                                s+=storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j);
+                                            } else {
+                                                s+=storedCodeBlock.charAt(j);
                                             }
-                                            startPos=j+1;
+                                            startPos=j+1;
                                         }
-                                    } else {
-                                        s+=storedCodeBlock.charAt(j);
-                                        startPos=j+1;
+                                    } else {
+                                        s+=storedCodeBlock.charAt(j);
+                                        startPos=j+1;
                                     }
-                                    if (canBeNumericalConstant&&lengthOfConstant==0&&!(storedCodeBlock.charAt(j)>='0'&&storedCodeBlock.charAt(j)<='9')) {
-                                        canBeNumericalConstant=false;
+                                    if (canBeNumericalConstant&&lengthOfConstant==0&&!(storedCodeBlock.charAt(j)>="0"&&storedCodeBlock.charAt(j)<="9")) {
+                                        canBeNumericalConstant=false;
                                     }
-                                    if (!canBeNumericalConstant&&!isAlphanumeric(j)) {
-                                        canBeNumericalConstant=true;
-                                        lengthOfConstant=0;
-                                        System.out.println("Found "+storedCodeBlock.charAt(j)+", can be numeric...");
+                                    if (!canBeNumericalConstant&&!isAlphanumeric(j)) {
+                                        canBeNumericalConstant=true;
+                                        lengthOfConstant=0;
+                                        System.out.println("Found "+storedCodeBlock.charAt(j)+", can be numeric...");
                                     }
                                 }
-                                s+=endText;
-                                //System.out.println("Stored code block: "+storedCodeBlock);
-                            } else 
-                            if (inCodeBlock) {
-                                storedCodeBlock+=s+"\";
-                                s=" ";
+                                s+=endText;
+                                //System.out.println("Stored code block: "+storedCodeBlock);
+                            } else 
+                            if (inCodeBlock) {
+                                storedCodeBlock+=s+"\n";
+                                s=" ";
                             }
                         }
-                        if (s.length()>0&&isArticleFile(f)) {
-                            //Check for markdown pieces.
-                            if (s.charAt(0)=='-') {
-                                //Start of a title piece.
-                                s=s.replace("-",map.get("$TITLE_CONTENT_"));
-                                s=s+map.get("$TITLE_CONTENT_").replace("%ID%","id=\"content_"+f+"\"");
-                                //Use ⤈ if there's more text to be shown than can fit.
+                        if (s.length()>0&&isArticleFile(f)) {
+                            //Check for markdown pieces.
+                            if (s.charAt(0)=="-") {
+                                //Start of a title piece.
+                                s=s.replace("-",map.get("$TITLE_CONTENT_START"));
+                                s=s+map.get("$TITLE_CONTENT_END").replace("%ID%","id=\"content_"+f+"\"");
+                                //Use if "s more text to be shown than can fit.
                             } else
-                            if (s.contains("===")) {
-                                s=map.get("$CONTENT_")+map.get("$DATE_CONTENT_")+s.replace("===","")+map.get("$CONTENT_")+"%CONDITIONAL_EXPAND%"+map.get("$CONTENT_");
+                            if (s.contains("===")) {
+                                s=map.get("$CONTENT_END")+map.get("$DATE_CONTENT_START")+s.replace("===","")+map.get("$CONTENT_END")+"%CONDITIONAL_EXPAND%"+map.get("$CONTENT_END");
                             } else 
-                            if (s.charAt(0)==':') {
+                            if (s.charAt(0)==":") {
                                 //Image with caption.
                                 //Format:
                                 //:<url>,<left|right|center>,<width>,<caption>
-                                String[] splitter = s.split(Pattern.quote(","));
+                                String[] splitter = s.split(Pattern.quote(","));
                                 StringBuilder captionText = new StringBuilder(splitter[3]);
                                 for (int j=4;j<splitter.length;j++) {
-                                    captionText.append(",").append(splitter[j]);
+                                    captionText.append(",").append(splitter[j]);
                                 }
-                                s="<div><figure style=\"text-align:center;"+((splitter[1].equals("left")||splitter[1].equals("right"))?"width:"+splitter[2]+"%;float:"+splitter[1]+";":"")+"\"><img src=\"/"+splitter[0].substring(1)+"\" style=\"margin:auto;width:100%;\"><figcaption>"+captionText.toString()+"</figcaption></figure></div>";
+                                s="<div><figure style=\"text-align:center;"+((splitter[1].equals("left")||splitter[1].equals("right"))?"width:"+splitter[2]+"%;float:"+splitter[1]+";":"")+"\"><img src=\"/"+splitter[0].substring(1)+"\" style=\"margin:auto;width:100%;\"><figcaption>"+captionText.toString()+"</figcaption></figure></div>";
                             } else {
-                                //It's regular content, so add paragraphs.
-                                s="<p class=\"color"+(((int)(COLOR_ROTATION=(COLOR_ROTATION+0.4)%6))+1)+"\">"+s+"</p>";
+                                //It"s regular content, so add paragraphs.
+                                s="<p class=\""+(((int)(COLOR_ROTATION=(COLOR_ROTATION+0.4)%6))+1)+"\">"+s+"</p>";
                             }
-                        } else 
-                        if (s.length()==0&&isArticleFile(f)) {
-                            s="<br/>"; //Setup a line break here.
+                        } else 
+                        if (s.length()==0&&isArticleFile(f)) {
+                            s="<br/>"; //Setup a line break here.
                         }
-                        for (String key : map.keySet()) {
-                            s=s.replaceAll(Pattern.quote(key),map.get(key));
+                        for (String key : map.keySet()) {
+                            s=s.replaceAll(Pattern.quote(key),map.get(key));
                         }
-                        content.set(i,s);
+                        content.set(i,s);
                     }
-                    System.out.println("  Writing to "+f.toAbsolutePath());
-                    Files.write(f, content, Charset.defaultCharset(),StandardOpenOption.CREATE,StandardOpenOption.TRUNCATE_EXISTING,StandardOpenOption.WRITE);
+                    System.out.println("  Writing to "+f.toAbsolutePath());
+                    Files.write(f, content, Charset.defaultCharset(),StandardOpenOption.CREATE,StandardOpenOption.TRUNCATE_EXISTING,StandardOpenOption.WRITE);
                     
-                    System.out.println(" "+f.getFileName() + " conversion complete!");
-                } catch (IOException e) {
-                    e.printStackTrace();
+                    System.out.println(" "+f.getFileName() + " conversion complete!");
+                } catch (IOException e) {
+                    e.printStackTrace();
                 }
             }
         }
     }
-    private static boolean validNumericalConstantCharacters(int lengthOfConstant, int j) {
-        return storedCodeBlock.charAt(j)>='0'&&storedCodeBlock.charAt(j)<='9'||lengthOfConstant>0&&storedCodeBlock.charAt(j)=='.'||lengthOfConstant>0&&storedCodeBlock.charAt(j)>='A'&&lengthOfConstant>0&&storedCodeBlock.charAt(j)<='F'||lengthOfConstant>0&&storedCodeBlock.charAt(j)>='a'&&lengthOfConstant>0&&storedCodeBlock.charAt(j)<='f'||lengthOfConstant>0&&storedCodeBlock.charAt(j)=='x'||lengthOfConstant>0&&storedCodeBlock.charAt(j)=='X';
+    private static boolean validNumericalConstantCharacters(int lengthOfConstant, int j) {
+        return storedCodeBlock.charAt(j)>="0"&&storedCodeBlock.charAt(j)<="9"||lengthOfConstant>0&&storedCodeBlock.charAt(j)=="."||lengthOfConstant>0&&storedCodeBlock.charAt(j)>="A"&&lengthOfConstant>0&&storedCodeBlock.charAt(j)<="F"||lengthOfConstant>0&&storedCodeBlock.charAt(j)>="a"&&lengthOfConstant>0&&storedCodeBlock.charAt(j)<="f"||lengthOfConstant>0&&storedCodeBlock.charAt(j)=="x"||lengthOfConstant>0&&storedCodeBlock.charAt(j)=="X";
     }
-    private static boolean isAlphanumeric(int j) {
-        return storedCodeBlock.charAt(j)>='0'&&storedCodeBlock.charAt(j)<='9'||storedCodeBlock.charAt(j)>='A'&&storedCodeBlock.charAt(j)<='Z'||storedCodeBlock.charAt(j)>='a'&&storedCodeBlock.charAt(j)<='z';
+    private static boolean isAlphanumeric(int j) {
+        return storedCodeBlock.charAt(j)>="0"&&storedCodeBlock.charAt(j)<="9"||storedCodeBlock.charAt(j)>="A"&&storedCodeBlock.charAt(j)<="Z"||storedCodeBlock.charAt(j)>="a"&&storedCodeBlock.charAt(j)<="z";
     }
     /**
-     * Writes a span tag with the included class.
+     * Writes a span tag with the included class.
      * **/
-    private static String SPAN(String className) {
-        return "<span class=\""+className+"\">";
+    private static String SPAN(String className) {
+        return "<span class=\""+className+"\">";
     }
-    private static void GenerateArticleFiles(Iterator<Path> items){
-        System.out.println(" Generating article files...");
-        while (items.hasNext()) {
-            Path f = items.next();
-            try {
-                if (Files.isRegularFile(f)&&isArticleFile(f)) {
-                    System.out.println("  Creating article for "+f.getFileName());
-                    List<String> content = Files.readAllLines(f);
-                    List<String> preContent = Files.readAllLines(ops.get("%"));
-                    List<String> postContent = Files.readAllLines(ops.get("%"));
-                    StringBuilder sb = new StringBuilder();
-                    for (String d : preContent) {
-                        for (String k : sigPlace.map.keySet()) {
-                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
+    private static void GenerateArticleFiles(Iterator<Path> items){
+        System.out.println(" Generating article files...");
+        while (items.hasNext()) {
+            Path f = items.next();
+            try {
+                if (Files.isRegularFile(f)&&isArticleFile(f)) {
+                    System.out.println("  Creating article for "+f.getFileName());
+                    List<String> content = Files.readAllLines(f);
+                    List<String> preContent = Files.readAllLines(ops.get("%DEFAULT"));
+                    List<String> postContent = Files.readAllLines(ops.get("%FOOTER"));
+                    StringBuilder sb = new StringBuilder();
+                    for (String d : preContent) {
+                        for (String k : sigPlace.map.keySet()) {
+                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
                         }
-                        sb.append(d).append("\");
+                        sb.append(d).append("\n");
                     }
-                    for (String d : content) {
-                        for (String k : sigPlace.map.keySet()) {
-                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
+                    for (String d : content) {
+                        for (String k : sigPlace.map.keySet()) {
+                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
                         }
-                        d=d.replaceFirst("div class=\"content\"","div class=\"expandedContent\"");
-                        d=d.replaceFirst("%CONDITIONAL_EXPAND%","");
-                        sb.append(d).append("\");
+                        d=d.replaceFirst("div class=\"content\"","div class=\"expandedContent\"");
+                        d=d.replaceFirst("%CONDITIONAL_EXPAND%","");
+                        sb.append(d).append("\n");
                     }
-                    for (String d : postContent) {
-                        for (String k : sigPlace.map.keySet()) {
-                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
+                    for (String d : postContent) {
+                        for (String k : sigPlace.map.keySet()) {
+                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
                         }
-                        sb.append(d).append("\");
+                        sb.append(d).append("\n");
                     }
-                    Files.write(Paths.get(f.getParent().toString(),f.getFileName()+"."),sb.toString().getBytes());
+                    Files.write(Paths.get(f.getParent().toString(),f.getFileName()+".html"),sb.toString().getBytes());
                 }
-            } catch (IOException e) {
-                e.printStackTrace();
+            } catch (IOException e) {
+                e.printStackTrace();
             }
         }
     }
-    private static void ConvertArticleReferences(Iterator<Path> items) {
-        while (items.hasNext()) {
-            Path f = items.next();
-            System.out.println(" Looking for Article References..."+f.getFileName());
-            boolean articleJavascriptIncluded=false;
-            if (Files.isRegularFile(f)&&isHTMLFile(f)) {
-                System.out.println("  Searching "+f.getFileName());
-                try {
-                    List<String> content = Files.readAllLines(f);
-                    for (int i=0;i<content.size();i++) {
-                        String s = content.get(i);
-                        if (s.length()>0&&s.contains("$ARTICLE_")) {
-                            String article = ARTICLESDIR+"/"+s.replace("$ARTICLE_PREVIEW ","")+".";
-                            System.out.println("   Found article preview request in "+f.getFileName()+" for article "+article+".");
-                            Path file = Paths.get(OUTDIR,article);
-                            List<String> newData = Files.readAllLines(file);
-                            if (newData.size()>0) {
-                                content.set(i,newData.get(0));
-                                for (int j=1;j<newData.size();j++) {
-                                    content.add(i+j, newData.get(j));
+    private static void ConvertArticleReferences(Iterator<Path> items) {
+        while (items.hasNext()) {
+            Path f = items.next();
+            System.out.println(" Looking for Article References..."+f.getFileName());
+            boolean articleJavascriptIncluded=false;
+            if (Files.isRegularFile(f)&&isHTMLFile(f)) {
+                System.out.println("  Searching "+f.getFileName());
+                try {
+                    List<String> content = Files.readAllLines(f);
+                    for (int i=0;i<content.size();i++) {
+                        String s = content.get(i);
+                        if (s.length()>0&&s.contains("$ARTICLE_PREVIEW")) {
+                            String article = ARTICLESDIR+"/"+s.replace("$ARTICLE_PREVIEW ","")+".article";
+                            System.out.println("   Found article preview request in "+f.getFileName()+" for article "+article+".");
+                            Path file = Paths.get(OUTDIR,article);
+                            List<String> newData = Files.readAllLines(file);
+                            if (newData.size()>0) {
+                                content.set(i,newData.get(0));
+                                for (int j=1;j<newData.size();j++) {
+                                    content.add(i+j, newData.get(j));
                                 }
-                                String lastline=content.get(i+newData.size()-1);
-                                lastline=lastline.replace("%CONDITIONAL_EXPAND%","<div class=\"unexpanded\" id=\"expand_"+i+"\" onClick=\"expand(this,'"+Paths.get(OUTDIR,article.toString())+"')\"><br/><br/><br/><br/>&#x2908; Click to expand.</div>");
-                                content.set(i+newData.size()-1,lastline);//<div class=\"unexpanded\" id=\"expand_"+i+"\" onClick=\"expand("+i+")\"><br/><br/><br/><br/>⤈ Click to expand.</div>");
-                            } else {
-                                content.set(i,"");
+                                String lastline=content.get(i+newData.size()-1);
+                                lastline=lastline.replace("%CONDITIONAL_EXPAND%","<div class=\"unexpanded\" id=\"expand_"+i+"\" onClick=\"expand(this,""+Paths.get(OUTDIR,article.toString())+"")\"><br/><br/><br/><br/>⤈ Click to expand.</div>");
+                                content.set(i+newData.size()-1,lastline);//<div class=\"unexpanded\" id=\"expand_"+i+"\" onClick=\"expand("+i+")\"><br/><br/><br/><br/>&#x2908; Click to expand.</div>");
+                            } else {
+                                content.set(i,"");
                             }
-                            if (!articleJavascriptIncluded) {
-                                List<String> articlejs = Files.readAllLines(Paths.get(REFDIR,"article.js"));
-                                for (int j=articlejs.size()-1;j>=0;j--) {
-                                    content.add(i,articlejs.get(j));
+                            if (!articleJavascriptIncluded) {
+                                List<String> articlejs = Files.readAllLines(Paths.get(REFDIR,"article."));
+                                for (int j=articlejs.size()-1;j>=0;j--) {
+                                    content.add(i,articlejs.get(j));
                                 }
-                                articleJavascriptIncluded=true;
+                                articleJavascriptIncluded=true;
                             }
                         }
                     }
-                    Files.write(f,content);
-                } catch (IOException e) {
-                    e.printStackTrace();
+                    Files.write(f,content);
+                } catch (IOException e) {
+                    e.printStackTrace();
                 }
             }
         }
     }
-    static void copyDirectory(String sourceDirectoryLocation, String destinationDirectoryLocation) 
-    throws IOException {
-        Files.walk(Paths.get(sourceDirectoryLocation))
-        .forEach(source -> {
-            Path destination = Paths.get(destinationDirectoryLocation, source.toString()
-                .substring(sourceDirectoryLocation.length()));
-            try {
-                if (Files.isDirectory(destination)) {
-                    Files.createDirectories(destination);
-                } else {
-                    Files.copy(source, destination, new CopyOption[]{StandardCopyOption.COPY_ATTRIBUTES,StandardCopyOption.REPLACE_EXISTING});
+    static void copyDirectory(String sourceDirectoryLocation, String destinationDirectoryLocation) 
+    throws IOException {
+        Files.walk(Paths.get(sourceDirectoryLocation))
+        .forEach(source -> {
+            Path destination = Paths.get(destinationDirectoryLocation, source.toString()
+                .substring(sourceDirectoryLocation.length()));
+            try {
+                if (Files.isDirectory(destination)) {
+                    Files.createDirectories(destination);
+                } else {
+                    Files.copy(source, destination, new CopyOption[]{StandardCopyOption.COPY_ATTRIBUTES,StandardCopyOption.REPLACE_EXISTING});
                 }
-            } catch (IOException e) {
-                e.printStackTrace();
+            } catch (IOException e) {
+                e.printStackTrace();
             }
         });
     }
-    static void buildDirectoryListings() 
-    throws IOException {
-        String startingPath=Paths.get(sigPlace.OUTDIR).toAbsolutePath().toString();
-        HashMap<String,List<Path>> map = new HashMap<>();
-        Iterator<Path> it = Files.walk(Paths.get(sigPlace.OUTDIR)).iterator();
-        map.put("/",new ArrayList<Path>());
-        while (it.hasNext()) {
-            Path f = it.next();
-            if (!f.getFileName().toString().equals(OUTDIR)) {
-                String myKey = f.toAbsolutePath().toString().replace(startingPath,"").replace(f.getFileName().toString(),"");
-                //System.out.println(myKey+","+f);
-                map.putIfAbsent(myKey,new ArrayList<Path>());
-                map.get(myKey).add(f);
+    static void buildDirectoryListings() 
+    throws IOException {
+        String startingPath=Paths.get(sigPlace.OUTDIR).toAbsolutePath().toString();
+        HashMap<String,List<Path>> map = new HashMap<>();
+        Iterator<Path> it = Files.walk(Paths.get(sigPlace.OUTDIR)).iterator();
+        map.put("/",new ArrayList<Path>());
+        while (it.hasNext()) {
+            Path f = it.next();
+            if (!f.getFileName().toString().equals(OUTDIR)) {
+                String myKey = f.toAbsolutePath().toString().replace(startingPath,"").replace(f.getFileName().toString(),"");
+                //System.out.println(myKey+","+f);
+                map.putIfAbsent(myKey,new ArrayList<Path>());
+                map.get(myKey).add(f);
             }
         }
-        System.out.println("Directory structure determined:");
-        System.out.println("    "+map);
-        for (String key : map.keySet()) {
-            System.out.println("Creating directory listing for "+key+"...");
-            StringBuilder sb = new StringBuilder("");
-            List<String> data = Files.readAllLines(ops.get("%DEFAULT"));
-            List<String> data2 = Files.readAllLines(ops.get("%FOOTER"));
-            for (String d : data) {
-                for (String k : sigPlace.map.keySet()) {
-                    d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
+        System.out.println("Directory structure determined:");
+        System.out.println("    "+map);
+        for (String key : map.keySet()) {
+            System.out.println("Creating directory listing for "+key+"...");
+            StringBuilder sb = new StringBuilder("");
+            List<String> data = Files.readAllLines(ops.get("%"));
+            List<String> data2 = Files.readAllLines(ops.get("%"));
+            for (String d : data) {
+                for (String k : sigPlace.map.keySet()) {
+                    d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
                 }
-                sb.append(d).append("\n");
+                sb.append(d).append("\");
             }
-            sb.append("<h2>Directory Listing for "+key+"</h2>");
-            sb.append("<div class=\"folderlisting\"><a href=\"")
-            .append(key)
-            .append("..\" class=\"icon\">📁</a><a href=\"")
-            .append(key)
-            .append("..\">.. </a><a href=\"")
-            .append(key)
-            .append("..\" class=\"nounderline\">(Previous Directory)</a></div>");
-            for (Path f : map.get(key)) {
-                sb.append("<div class=\"").append((Files.isDirectory(f)?"":"")).append("\">")
-                .append("<a href=\""+(f.toAbsolutePath().toString().replace(Paths.get(OUTDIR).toAbsolutePath().toString(),""))+"\" class=\"icon\">")
-                .append((Files.isDirectory(f)?"📁":"🗎"))
-                .append("</a>")
-                .append("<a href=\""+(f.toAbsolutePath().toString().replace(Paths.get(OUTDIR).toAbsolutePath().toString(),""))+"\">")
-                .append(f.getFileName())
-                .append("</a>\t")
-                .append(Files.getLastModifiedTime(f))
-                .append("\t")
-                .append(Files.getOwner(f))
-                .append("\t")
-                .append(Files.size(f))
-                .append("</div>\n");
+            sb.append("<h2>Directory Listing for "+key+"</h2>");
+            sb.append("<div class=\"folderlisting\"><a href=\"")
+            .append(key)
+            .append("..\" class=\"icon\">&#x1F4C1;</a><a href=\"")
+            .append(key)
+            .append("..\">.. </a><a href=\"")
+            .append(key)
+            .append("..\" class=\"nounderline\">(Previous Directory)</a></div>");
+            for (Path f : map.get(key)) {
+                sb.append("<div class=\"").append((Files.isDirectory(f)?"folderlisting":"filelisting")).append("\">")
+                .append("<a href=\""+(f.toAbsolutePath().toString().replace(Paths.get(OUTDIR).toAbsolutePath().toString(),""))+"\" class=\"icon\">")
+                .append((Files.isDirectory(f)?"&#x1F4C1;":"&#x1F5CE;"))
+                .append("</a>")
+                .append("<a href=\""+(f.toAbsolutePath().toString().replace(Paths.get(OUTDIR).toAbsolutePath().toString(),""))+"\">")
+                .append(f.getFileName())
+                .append("</a>\")
+                .append(Files.getLastModifiedTime(f))
+                .append("\")
+                .append(Files.getOwner(f))
+                .append("\")
+                .append(Files.size(f))
+                .append("</div>\");
             }
-            for (String d : data2) {
-                for (String k : sigPlace.map.keySet()) {
-                    d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
+            for (String d : data2) {
+                for (String k : sigPlace.map.keySet()) {
+                    d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
                 }
-                sb.append(d).append("\n");
+                sb.append(d).append("\");
             }
-            Path newf = Files.write(Paths.get(OUTDIR,key,DIRECTORYLISTING_FILENAME),sb.toString().getBytes());
-            System.out.println("  Added info for ("+map.size()+") files to "+newf.toAbsolutePath());
+            Path newf = Files.write(Paths.get(OUTDIR,key,DIRECTORYLISTING_FILENAME),sb.toString().getBytes());
+            System.out.println("  Added info for ("+map.size()+") files to "+newf.toAbsolutePath());
         }
     }
-    private static boolean isArticleFile(Path f) {
-        return f.getFileName().toString().contains(".article");
+    private static boolean isArticleFile(Path f) {
+        return f.getFileName().toString().contains(".");
     }
-    private static boolean isHTMLFile(Path f) {
-        return f.getFileName().toString().contains(".html");
+    private static boolean isHTMLFile(Path f) {
+        return f.getFileName().toString().contains(".");
     }
-    private static void ExportCodeFile() {
-        try {
-            Path file = Paths.get("sigServer.java");
-            List<String> data = Files.readAllLines(file);
-            int i=0;
-            while (!data.get(i++).contains("sigServer()")&&i<data.size());
-            if (i<data.size()) {
-                Files.write(Paths.get(OUTDIR,"codeBackground"),data.subList(i, Math.min(i+40,data.size())),Charset.defaultCharset(),StandardOpenOption.CREATE,StandardOpenOption.TRUNCATE_EXISTING,StandardOpenOption.WRITE);
+    private static void ExportCodeFile() {
+        try {
+            Path file = Paths.get("sigServer.");
+            List<String> data = Files.readAllLines(file);
+            int i=0;
+            while (!data.get(i++).contains("sigServer()")&&i<data.size());
+            if (i<data.size()) {
+                Files.write(Paths.get(OUTDIR,""),data.subList(i, Math.min(i+40,data.size())),Charset.defaultCharset(),StandardOpenOption.CREATE,StandardOpenOption.TRUNCATE_EXISTING,StandardOpenOption.WRITE);
             }
-        } catch (IOException e) {
-            e.printStackTrace();
+        } catch (IOException e) {
+            e.printStackTrace();
         }
         
     }
diff --git a/out/articles/sigplace1.article.html b/out/articles/sigplace1.article.html
index 688ce94..63a6fa5 100644
--- a/out/articles/sigplace1.article.html
+++ b/out/articles/sigplace1.article.html
@@ -18,37 +18,37 @@
 
 

Welcome to SigPlace!

-

+

This is a SigPlace article! It will contain information that is important (probably) and will be layed out as such.

-

+

Paragraphs are automatically split up for readability and generated correctly via the parser. There's quite a bit of flexibility with the system and makes it easy to post updates should they be required.

-

+

A lot of content management systems would do this by having a web interface and submitting content and managing it that way, but by coding my own management system and using the built-in OS' filesystem to handle the work, I save myself a lot of pains and headaches.

-

+

Lorem ipsum dolor sit amet, consectetur adipiscing elit. In feugiat, urna ut sollicitudin luctus, nulla magna faucibus mauris, at semper nisl nisi ut mauris. Vestibulum cursus tortor velit, ut congue ex porta in. Nullam hendrerit risus sit amet neque euismod faucibus. Sed ac diam non lectus euismod pulvinar eu non mauris. Donec accumsan nisl efficitur, sodales lectus et, finibus quam. Sed vel consectetur leo. Cras ut condimentum quam. Aliquam molestie viverra congue. Donec scelerisque nibh ac nulla dictum semper. Aliquam id massa a massa bibendum finibus id ac sapien. Integer vitae ullamcorper enim, non semper massa.


-

+

Proin cursus sodales elit, vitae volutpat mi fermentum a. In vitae magna quis leo cursus accumsan id facilisis purus. Vestibulum accumsan iaculis turpis eu sollicitudin. Sed ultricies felis non elit suscipit interdum. Maecenas sollicitudin turpis justo, vel pretium sapien scelerisque eget. Nullam sagittis finibus risus ut aliquam. Praesent quam orci, dapibus ut ex ac, sodales dapibus nunc.


-

+

Fusce magna risus, iaculis non justo sit amet, semper sodales urna. Morbi eu eros lectus. Integer euismod venenatis eros a hendrerit. Nulla ultricies lectus nec quam condimentum fermentum. Quisque a turpis vitae orci pharetra ullamcorper. Nunc fringilla vitae nunc a aliquam. In aliquam gravida massa. Sed imperdiet dignissim sapien, ullamcorper rutrum lacus convallis ut.


-

+

Nunc tortor sem, dapibus mattis varius id, varius eu leo. Phasellus efficitur nulla a diam faucibus, id facilisis lacus malesuada. Nulla condimentum egestas erat a fermentum. Ut interdum dui id est condimentum, vel fermentum nisi ornare. Sed eu rhoncus magna, sit amet finibus eros. In a nibh tincidunt, suscipit tellus eleifend, faucibus mauris. Vestibulum sagittis nisi et efficitur ullamcorper. Donec sodales efficitur ligula id congue. Etiam egestas tristique interdum. Mauris at massa eget metus pellentesque fermentum nec non lacus. Nulla turpis nunc, feugiat vel euismod ac, maximus id est. Praesent cursus elit ac dolor hendrerit lacinia.


-

+

Vestibulum laoreet lorem consequat, mollis augue finibus, luctus libero. Praesent convallis sed velit vitae molestie. Vestibulum nec fringilla tellus, non dictum nulla. Donec tempor ac diam sit amet porta. Quisque mi ex, vulputate ac tincidunt vel, vestibulum vitae orci. Duis gravida mauris eget mauris pulvinar, lobortis tincidunt neque efficitur. Nunc blandit metus vitae faucibus vulputate. Curabitur rhoncus volutpat lorem, sit amet pulvinar ipsum. Fusce ultricies enim odio, a viverra quam tincidunt quis. Aliquam sollicitudin a sapien id efficitur. Proin at finibus elit, id gravida elit. Nulla facilisi. Ut tincidunt, ligula eu pulvinar dapibus, lorem nisl facilisis tellus, in ornare quam dolor quis libero. Pellentesque ut convallis orci. Donec volutpat nunc velit, tristique convallis purus lacinia sit amet. Maecenas porttitor cursus nisl sed porta.


Hello there! You can see this is the Love Live logo indeed! It is quite smol right now but that's okay. Let's keep on going with the text. If the caption is really long and with commas, they will now be combined,,,,,see how that works? Amazing!
-

+

Here we demonstrate the love live logo. But wait, it's literally like in the middle wtf is going on.Here we demonstrate the love live logo. But wait, it's literally like in the middle wtf is going on.Here we demonstrate the love live logo. But wait, it's literally like in the middle wtf is going on.


@@ -515,7 +515,7 @@ Here we demonstrate the love live logo. But wait, it's literally like in the mid -

+

 import java.io.IOException;
 import java.nio.charset.Charset;
@@ -641,322 +641,322 @@ Here we demonstrate the love live logo. But wait, it's literally like in the mid
                                 String endText=s.substring(s.indexOf("</pre>")+"</pre>".length(),s.length());
                                 s="";
                                 for (int j=0;j<storedCodeBlock.length();j++) {
-                                    if (storedCodeBlock.charAt(j)=='"') {
-                                        inString=!inString;
-                                        if (inString) {
-                                            s+=SPAN("")+"\"";
-                                        } else {
-                                            s+="\"</span>";
-                                            startPos=j+1;
+                                    if (storedCodeBlock.charAt(j)==""") {
+                                        inString=!inString;
+                                        if (inString) {
+                                            s+=SPAN("string")+"\"";
+                                        } else {
+                                            s+="\"</span>";
+                                            startPos=j+1;
                                         }
                                     } else
-                                    if (!inString&&!inChar) {
-                                        if (canBeNumericalConstant&&validNumericalConstantCharacters(lengthOfConstant, j)) {
+                                    if (!inString&&!inChar) {
+                                        if (canBeNumericalConstant&&validNumericalConstantCharacters(lengthOfConstant, j)) {
                                             lengthOfConstant++;
-                                            System.out.println("Length of Constant now "+lengthOfConstant);
+                                            System.out.println("Length of Constant now "+lengthOfConstant);
                                         }
-                                        if (canBeNumericalConstant&&lengthOfConstant>0&&!(validNumericalConstantCharacters(lengthOfConstant, j))) {
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            //System.out.println("Setting "+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j));
-                                            lengthOfConstant=0;
-                                            canBeNumericalConstant=false;
-                                            startPos=j+1;
+                                        if (canBeNumericalConstant&&lengthOfConstant>0&&!(validNumericalConstantCharacters(lengthOfConstant, j))) {
+                                            s+=SPAN("number")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
+                                            //System.out.println("Setting "+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j));
+                                            lengthOfConstant=0;
+                                            canBeNumericalConstant=false;
+                                            startPos=j+1;
                                         } else
-                                        if (!canBeNumericalConstant&&storedCodeBlock.charAt(j)=='.') {
-                                            //Previous section was a member.
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else 
-                                        if (j>3&&storedCodeBlock.substring(j-3,j+1).equals("true")&&!isAlphanumeric(j-4)&&!isAlphanumeric(j+1)) {
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j)+"</span>";
-                                            startPos=j+1;
-                                        } else 
-                                        if (j>4&&storedCodeBlock.substring(j-4,j+1).equals("false")&&!isAlphanumeric(j-5)&&!isAlphanumeric(j+1)) {
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j)+"</span>";
-                                            startPos=j+1;
-                                        } else 
-                                        if (storedCodeBlock.charAt(j)=='(') {
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else 
-                                        if (j>0&&isAlphanumeric(j-1) && storedCodeBlock.charAt(j)==' '&&storedCodeBlock.charAt(j-1)!=' ') {
-                                            //Previous section was a keyword.
-                                            keyword=true;
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else 
-                                        if (j>0&&isAlphanumeric(j-1) && (storedCodeBlock.charAt(j)==';'||storedCodeBlock.charAt(j)==':')) {
-                                            //Previous section was a keyword.
-                                            //keyword=true;
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else 
-                                        if (keyword&&!(storedCodeBlock.charAt(j)>='0'&&storedCodeBlock.charAt(j)<='9'||storedCodeBlock.charAt(j)>='A'&&storedCodeBlock.charAt(j)<='Z'||storedCodeBlock.charAt(j)>='a'&&storedCodeBlock.charAt(j)<='z'||storedCodeBlock.charAt(j)==' ')) {
-                                            keyword=false;
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
+                                        if (!canBeNumericalConstant&&storedCodeBlock.charAt(j)==".") {
+                                            //Previous section was a member.
+                                            s+=SPAN("class")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
+                                            startPos=j+1;
+                                        } else 
+                                        if (j>3&&storedCodeBlock.substring(j-3,j+1).equals("true")&&!isAlphanumeric(j-4)&&!isAlphanumeric(j+1)) {
+                                            s+=SPAN("number")+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j)+"</span>";
+                                            startPos=j+1;
+                                        } else 
+                                        if (j>4&&storedCodeBlock.substring(j-4,j+1).equals("false")&&!isAlphanumeric(j-5)&&!isAlphanumeric(j+1)) {
+                                            s+=SPAN("number")+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j)+"</span>";
+                                            startPos=j+1;
+                                        } else 
+                                        if (storedCodeBlock.charAt(j)=="(") {
+                                            s+=SPAN("function")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
+                                            startPos=j+1;
+                                        } else 
+                                        if (j>0&&isAlphanumeric(j-1) && storedCodeBlock.charAt(j)==" "&&storedCodeBlock.charAt(j-1)!=" ") {
+                                            //Previous section was a keyword.
+                                            keyword=true;
+                                            s+=SPAN("keyword")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
+                                            startPos=j+1;
+                                        } else 
+                                        if (j>0&&isAlphanumeric(j-1) && (storedCodeBlock.charAt(j)==";"||storedCodeBlock.charAt(j)==":")) {
+                                            //Previous section was a keyword.
+                                            //keyword=true;
+                                            s+=SPAN("keyword")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
+                                            startPos=j+1;
+                                        } else 
+                                        if (keyword&&!(storedCodeBlock.charAt(j)>="0"&&storedCodeBlock.charAt(j)<="9"||storedCodeBlock.charAt(j)>="A"&&storedCodeBlock.charAt(j)<="Z"||storedCodeBlock.charAt(j)>="a"&&storedCodeBlock.charAt(j)<="z"||storedCodeBlock.charAt(j)==" ")) {
+                                            keyword=false;
+                                            s+=SPAN("variable")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
+                                            startPos=j+1;
                                         } else
-                                        if (!isAlphanumeric(j)){
-                                            if (startPos<j) {
-                                                s+=storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j);
-                                            } else {
-                                                s+=storedCodeBlock.charAt(j);
+                                        if (!isAlphanumeric(j)){
+                                            if (startPos<j) {
+                                                s+=storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j);
+                                            } else {
+                                                s+=storedCodeBlock.charAt(j);
                                             }
-                                            startPos=j+1;
+                                            startPos=j+1;
                                         }
-                                    } else {
-                                        s+=storedCodeBlock.charAt(j);
-                                        startPos=j+1;
+                                    } else {
+                                        s+=storedCodeBlock.charAt(j);
+                                        startPos=j+1;
                                     }
-                                    if (canBeNumericalConstant&&lengthOfConstant==0&&!(storedCodeBlock.charAt(j)>='0'&&storedCodeBlock.charAt(j)<='9')) {
-                                        canBeNumericalConstant=false;
+                                    if (canBeNumericalConstant&&lengthOfConstant==0&&!(storedCodeBlock.charAt(j)>="0"&&storedCodeBlock.charAt(j)<="9")) {
+                                        canBeNumericalConstant=false;
                                     }
-                                    if (!canBeNumericalConstant&&!isAlphanumeric(j)) {
-                                        canBeNumericalConstant=true;
-                                        lengthOfConstant=0;
-                                        System.out.println("Found "+storedCodeBlock.charAt(j)+", can be numeric...");
+                                    if (!canBeNumericalConstant&&!isAlphanumeric(j)) {
+                                        canBeNumericalConstant=true;
+                                        lengthOfConstant=0;
+                                        System.out.println("Found "+storedCodeBlock.charAt(j)+", can be numeric...");
                                     }
                                 }
-                                s+=endText;
-                                //System.out.println("Stored code block: "+storedCodeBlock);
-                            } else 
-                            if (inCodeBlock) {
-                                storedCodeBlock+=s+"\";
-                                s=" ";
+                                s+=endText;
+                                //System.out.println("Stored code block: "+storedCodeBlock);
+                            } else 
+                            if (inCodeBlock) {
+                                storedCodeBlock+=s+"\n";
+                                s=" ";
                             }
                         }
-                        if (s.length()>0&&isArticleFile(f)) {
-                            //Check for markdown pieces.
-                            if (s.charAt(0)=='-') {
-                                //Start of a title piece.
-                                s=s.replace("-",map.get("$TITLE_CONTENT_"));
-                                s=s+map.get("$TITLE_CONTENT_").replace("%ID%","id=\"content_"+f+"\"");
-                                //Use ⤈ if there's more text to be shown than can fit.
+                        if (s.length()>0&&isArticleFile(f)) {
+                            //Check for markdown pieces.
+                            if (s.charAt(0)=="-") {
+                                //Start of a title piece.
+                                s=s.replace("-",map.get("$TITLE_CONTENT_START"));
+                                s=s+map.get("$TITLE_CONTENT_END").replace("%ID%","id=\"content_"+f+"\"");
+                                //Use if "s more text to be shown than can fit.
                             } else
-                            if (s.contains("===")) {
-                                s=map.get("$CONTENT_")+map.get("$DATE_CONTENT_")+s.replace("===","")+map.get("$CONTENT_")+"%CONDITIONAL_EXPAND%"+map.get("$CONTENT_");
+                            if (s.contains("===")) {
+                                s=map.get("$CONTENT_END")+map.get("$DATE_CONTENT_START")+s.replace("===","")+map.get("$CONTENT_END")+"%CONDITIONAL_EXPAND%"+map.get("$CONTENT_END");
                             } else 
-                            if (s.charAt(0)==':') {
+                            if (s.charAt(0)==":") {
                                 //Image with caption.
                                 //Format:
                                 //:<url>,<left|right|center>,<width>,<caption>
-                                String[] splitter = s.split(Pattern.quote(","));
+                                String[] splitter = s.split(Pattern.quote(","));
                                 StringBuilder captionText = new StringBuilder(splitter[3]);
                                 for (int j=4;j<splitter.length;j++) {
-                                    captionText.append(",").append(splitter[j]);
+                                    captionText.append(",").append(splitter[j]);
                                 }
-                                s="<div><figure style=\"text-align:center;"+((splitter[1].equals("left")||splitter[1].equals("right"))?"width:"+splitter[2]+"%;float:"+splitter[1]+";":"")+"\"><img src=\"/"+splitter[0].substring(1)+"\" style=\"margin:auto;width:100%;\"><figcaption>"+captionText.toString()+"</figcaption></figure></div>";
+                                s="<div><figure style=\"text-align:center;"+((splitter[1].equals("left")||splitter[1].equals("right"))?"width:"+splitter[2]+"%;float:"+splitter[1]+";":"")+"\"><img src=\"/"+splitter[0].substring(1)+"\" style=\"margin:auto;width:100%;\"><figcaption>"+captionText.toString()+"</figcaption></figure></div>";
                             } else {
-                                //It's regular content, so add paragraphs.
-                                s="<p class=\"color"+(((int)(COLOR_ROTATION=(COLOR_ROTATION+0.4)%6))+1)+"\">"+s+"</p>";
+                                //It"s regular content, so add paragraphs.
+                                s="<p class=\""+(((int)(COLOR_ROTATION=(COLOR_ROTATION+0.4)%6))+1)+"\">"+s+"</p>";
                             }
-                        } else 
-                        if (s.length()==0&&isArticleFile(f)) {
-                            s="<br/>"; //Setup a line break here.
+                        } else 
+                        if (s.length()==0&&isArticleFile(f)) {
+                            s="<br/>"; //Setup a line break here.
                         }
-                        for (String key : map.keySet()) {
-                            s=s.replaceAll(Pattern.quote(key),map.get(key));
+                        for (String key : map.keySet()) {
+                            s=s.replaceAll(Pattern.quote(key),map.get(key));
                         }
-                        content.set(i,s);
+                        content.set(i,s);
                     }
-                    System.out.println("  Writing to "+f.toAbsolutePath());
-                    Files.write(f, content, Charset.defaultCharset(),StandardOpenOption.CREATE,StandardOpenOption.TRUNCATE_EXISTING,StandardOpenOption.WRITE);
+                    System.out.println("  Writing to "+f.toAbsolutePath());
+                    Files.write(f, content, Charset.defaultCharset(),StandardOpenOption.CREATE,StandardOpenOption.TRUNCATE_EXISTING,StandardOpenOption.WRITE);
                     
-                    System.out.println(" "+f.getFileName() + " conversion complete!");
-                } catch (IOException e) {
-                    e.printStackTrace();
+                    System.out.println(" "+f.getFileName() + " conversion complete!");
+                } catch (IOException e) {
+                    e.printStackTrace();
                 }
             }
         }
     }
-    private static boolean validNumericalConstantCharacters(int lengthOfConstant, int j) {
-        return storedCodeBlock.charAt(j)>='0'&&storedCodeBlock.charAt(j)<='9'||lengthOfConstant>0&&storedCodeBlock.charAt(j)=='.'||lengthOfConstant>0&&storedCodeBlock.charAt(j)>='A'&&lengthOfConstant>0&&storedCodeBlock.charAt(j)<='F'||lengthOfConstant>0&&storedCodeBlock.charAt(j)>='a'&&lengthOfConstant>0&&storedCodeBlock.charAt(j)<='f'||lengthOfConstant>0&&storedCodeBlock.charAt(j)=='x'||lengthOfConstant>0&&storedCodeBlock.charAt(j)=='X';
+    private static boolean validNumericalConstantCharacters(int lengthOfConstant, int j) {
+        return storedCodeBlock.charAt(j)>="0"&&storedCodeBlock.charAt(j)<="9"||lengthOfConstant>0&&storedCodeBlock.charAt(j)=="."||lengthOfConstant>0&&storedCodeBlock.charAt(j)>="A"&&lengthOfConstant>0&&storedCodeBlock.charAt(j)<="F"||lengthOfConstant>0&&storedCodeBlock.charAt(j)>="a"&&lengthOfConstant>0&&storedCodeBlock.charAt(j)<="f"||lengthOfConstant>0&&storedCodeBlock.charAt(j)=="x"||lengthOfConstant>0&&storedCodeBlock.charAt(j)=="X";
     }
-    private static boolean isAlphanumeric(int j) {
-        return storedCodeBlock.charAt(j)>='0'&&storedCodeBlock.charAt(j)<='9'||storedCodeBlock.charAt(j)>='A'&&storedCodeBlock.charAt(j)<='Z'||storedCodeBlock.charAt(j)>='a'&&storedCodeBlock.charAt(j)<='z';
+    private static boolean isAlphanumeric(int j) {
+        return storedCodeBlock.charAt(j)>="0"&&storedCodeBlock.charAt(j)<="9"||storedCodeBlock.charAt(j)>="A"&&storedCodeBlock.charAt(j)<="Z"||storedCodeBlock.charAt(j)>="a"&&storedCodeBlock.charAt(j)<="z";
     }
     /**
-     * Writes a span tag with the included class.
+     * Writes a span tag with the included class.
      * **/
-    private static String SPAN(String className) {
-        return "<span class=\""+className+"\">";
+    private static String SPAN(String className) {
+        return "<span class=\""+className+"\">";
     }
-    private static void GenerateArticleFiles(Iterator<Path> items){
-        System.out.println(" Generating article files...");
-        while (items.hasNext()) {
-            Path f = items.next();
-            try {
-                if (Files.isRegularFile(f)&&isArticleFile(f)) {
-                    System.out.println("  Creating article for "+f.getFileName());
-                    List<String> content = Files.readAllLines(f);
-                    List<String> preContent = Files.readAllLines(ops.get("%"));
-                    List<String> postContent = Files.readAllLines(ops.get("%"));
-                    StringBuilder sb = new StringBuilder();
-                    for (String d : preContent) {
-                        for (String k : sigPlace.map.keySet()) {
-                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
+    private static void GenerateArticleFiles(Iterator<Path> items){
+        System.out.println(" Generating article files...");
+        while (items.hasNext()) {
+            Path f = items.next();
+            try {
+                if (Files.isRegularFile(f)&&isArticleFile(f)) {
+                    System.out.println("  Creating article for "+f.getFileName());
+                    List<String> content = Files.readAllLines(f);
+                    List<String> preContent = Files.readAllLines(ops.get("%DEFAULT"));
+                    List<String> postContent = Files.readAllLines(ops.get("%FOOTER"));
+                    StringBuilder sb = new StringBuilder();
+                    for (String d : preContent) {
+                        for (String k : sigPlace.map.keySet()) {
+                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
                         }
-                        sb.append(d).append("\");
+                        sb.append(d).append("\n");
                     }
-                    for (String d : content) {
-                        for (String k : sigPlace.map.keySet()) {
-                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
+                    for (String d : content) {
+                        for (String k : sigPlace.map.keySet()) {
+                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
                         }
-                        d=d.replaceFirst("div class=\"content\"","div class=\"expandedContent\"");
-                        d=d.replaceFirst("%CONDITIONAL_EXPAND%","");
-                        sb.append(d).append("\");
+                        d=d.replaceFirst("div class=\"content\"","div class=\"expandedContent\"");
+                        d=d.replaceFirst("%CONDITIONAL_EXPAND%","");
+                        sb.append(d).append("\n");
                     }
-                    for (String d : postContent) {
-                        for (String k : sigPlace.map.keySet()) {
-                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
+                    for (String d : postContent) {
+                        for (String k : sigPlace.map.keySet()) {
+                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
                         }
-                        sb.append(d).append("\");
+                        sb.append(d).append("\n");
                     }
-                    Files.write(Paths.get(f.getParent().toString(),f.getFileName()+"."),sb.toString().getBytes());
+                    Files.write(Paths.get(f.getParent().toString(),f.getFileName()+".html"),sb.toString().getBytes());
                 }
-            } catch (IOException e) {
-                e.printStackTrace();
+            } catch (IOException e) {
+                e.printStackTrace();
             }
         }
     }
-    private static void ConvertArticleReferences(Iterator<Path> items) {
-        while (items.hasNext()) {
-            Path f = items.next();
-            System.out.println(" Looking for Article References..."+f.getFileName());
-            boolean articleJavascriptIncluded=false;
-            if (Files.isRegularFile(f)&&isHTMLFile(f)) {
-                System.out.println("  Searching "+f.getFileName());
-                try {
-                    List<String> content = Files.readAllLines(f);
-                    for (int i=0;i<content.size();i++) {
-                        String s = content.get(i);
-                        if (s.length()>0&&s.contains("$ARTICLE_")) {
-                            String article = ARTICLESDIR+"/"+s.replace("$ARTICLE_PREVIEW ","")+".";
-                            System.out.println("   Found article preview request in "+f.getFileName()+" for article "+article+".");
-                            Path file = Paths.get(OUTDIR,article);
-                            List<String> newData = Files.readAllLines(file);
-                            if (newData.size()>0) {
-                                content.set(i,newData.get(0));
-                                for (int j=1;j<newData.size();j++) {
-                                    content.add(i+j, newData.get(j));
+    private static void ConvertArticleReferences(Iterator<Path> items) {
+        while (items.hasNext()) {
+            Path f = items.next();
+            System.out.println(" Looking for Article References..."+f.getFileName());
+            boolean articleJavascriptIncluded=false;
+            if (Files.isRegularFile(f)&&isHTMLFile(f)) {
+                System.out.println("  Searching "+f.getFileName());
+                try {
+                    List<String> content = Files.readAllLines(f);
+                    for (int i=0;i<content.size();i++) {
+                        String s = content.get(i);
+                        if (s.length()>0&&s.contains("$ARTICLE_PREVIEW")) {
+                            String article = ARTICLESDIR+"/"+s.replace("$ARTICLE_PREVIEW ","")+".article";
+                            System.out.println("   Found article preview request in "+f.getFileName()+" for article "+article+".");
+                            Path file = Paths.get(OUTDIR,article);
+                            List<String> newData = Files.readAllLines(file);
+                            if (newData.size()>0) {
+                                content.set(i,newData.get(0));
+                                for (int j=1;j<newData.size();j++) {
+                                    content.add(i+j, newData.get(j));
                                 }
-                                String lastline=content.get(i+newData.size()-1);
-                                lastline=lastline.replace("%CONDITIONAL_EXPAND%","<div class=\"unexpanded\" id=\"expand_"+i+"\" onClick=\"expand(this,'"+Paths.get(OUTDIR,article.toString())+"')\"><br/><br/><br/><br/>&#x2908; Click to expand.</div>");
-                                content.set(i+newData.size()-1,lastline);//<div class=\"unexpanded\" id=\"expand_"+i+"\" onClick=\"expand("+i+")\"><br/><br/><br/><br/>⤈ Click to expand.</div>");
-                            } else {
-                                content.set(i,"");
+                                String lastline=content.get(i+newData.size()-1);
+                                lastline=lastline.replace("%CONDITIONAL_EXPAND%","<div class=\"unexpanded\" id=\"expand_"+i+"\" onClick=\"expand(this,""+Paths.get(OUTDIR,article.toString())+"")\"><br/><br/><br/><br/>⤈ Click to expand.</div>");
+                                content.set(i+newData.size()-1,lastline);//<div class=\"unexpanded\" id=\"expand_"+i+"\" onClick=\"expand("+i+")\"><br/><br/><br/><br/>&#x2908; Click to expand.</div>");
+                            } else {
+                                content.set(i,"");
                             }
-                            if (!articleJavascriptIncluded) {
-                                List<String> articlejs = Files.readAllLines(Paths.get(REFDIR,"article.js"));
-                                for (int j=articlejs.size()-1;j>=0;j--) {
-                                    content.add(i,articlejs.get(j));
+                            if (!articleJavascriptIncluded) {
+                                List<String> articlejs = Files.readAllLines(Paths.get(REFDIR,"article."));
+                                for (int j=articlejs.size()-1;j>=0;j--) {
+                                    content.add(i,articlejs.get(j));
                                 }
-                                articleJavascriptIncluded=true;
+                                articleJavascriptIncluded=true;
                             }
                         }
                     }
-                    Files.write(f,content);
-                } catch (IOException e) {
-                    e.printStackTrace();
+                    Files.write(f,content);
+                } catch (IOException e) {
+                    e.printStackTrace();
                 }
             }
         }
     }
-    static void copyDirectory(String sourceDirectoryLocation, String destinationDirectoryLocation) 
-    throws IOException {
-        Files.walk(Paths.get(sourceDirectoryLocation))
-        .forEach(source -> {
-            Path destination = Paths.get(destinationDirectoryLocation, source.toString()
-                .substring(sourceDirectoryLocation.length()));
-            try {
-                if (Files.isDirectory(destination)) {
-                    Files.createDirectories(destination);
-                } else {
-                    Files.copy(source, destination, new CopyOption[]{StandardCopyOption.COPY_ATTRIBUTES,StandardCopyOption.REPLACE_EXISTING});
+    static void copyDirectory(String sourceDirectoryLocation, String destinationDirectoryLocation) 
+    throws IOException {
+        Files.walk(Paths.get(sourceDirectoryLocation))
+        .forEach(source -> {
+            Path destination = Paths.get(destinationDirectoryLocation, source.toString()
+                .substring(sourceDirectoryLocation.length()));
+            try {
+                if (Files.isDirectory(destination)) {
+                    Files.createDirectories(destination);
+                } else {
+                    Files.copy(source, destination, new CopyOption[]{StandardCopyOption.COPY_ATTRIBUTES,StandardCopyOption.REPLACE_EXISTING});
                 }
-            } catch (IOException e) {
-                e.printStackTrace();
+            } catch (IOException e) {
+                e.printStackTrace();
             }
         });
     }
-    static void buildDirectoryListings() 
-    throws IOException {
-        String startingPath=Paths.get(sigPlace.OUTDIR).toAbsolutePath().toString();
-        HashMap<String,List<Path>> map = new HashMap<>();
-        Iterator<Path> it = Files.walk(Paths.get(sigPlace.OUTDIR)).iterator();
-        map.put("/",new ArrayList<Path>());
-        while (it.hasNext()) {
-            Path f = it.next();
-            if (!f.getFileName().toString().equals(OUTDIR)) {
-                String myKey = f.toAbsolutePath().toString().replace(startingPath,"").replace(f.getFileName().toString(),"");
-                //System.out.println(myKey+","+f);
-                map.putIfAbsent(myKey,new ArrayList<Path>());
-                map.get(myKey).add(f);
+    static void buildDirectoryListings() 
+    throws IOException {
+        String startingPath=Paths.get(sigPlace.OUTDIR).toAbsolutePath().toString();
+        HashMap<String,List<Path>> map = new HashMap<>();
+        Iterator<Path> it = Files.walk(Paths.get(sigPlace.OUTDIR)).iterator();
+        map.put("/",new ArrayList<Path>());
+        while (it.hasNext()) {
+            Path f = it.next();
+            if (!f.getFileName().toString().equals(OUTDIR)) {
+                String myKey = f.toAbsolutePath().toString().replace(startingPath,"").replace(f.getFileName().toString(),"");
+                //System.out.println(myKey+","+f);
+                map.putIfAbsent(myKey,new ArrayList<Path>());
+                map.get(myKey).add(f);
             }
         }
-        System.out.println("Directory structure determined:");
-        System.out.println("    "+map);
-        for (String key : map.keySet()) {
-            System.out.println("Creating directory listing for "+key+"...");
-            StringBuilder sb = new StringBuilder("");
-            List<String> data = Files.readAllLines(ops.get("%DEFAULT"));
-            List<String> data2 = Files.readAllLines(ops.get("%FOOTER"));
-            for (String d : data) {
-                for (String k : sigPlace.map.keySet()) {
-                    d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
+        System.out.println("Directory structure determined:");
+        System.out.println("    "+map);
+        for (String key : map.keySet()) {
+            System.out.println("Creating directory listing for "+key+"...");
+            StringBuilder sb = new StringBuilder("");
+            List<String> data = Files.readAllLines(ops.get("%"));
+            List<String> data2 = Files.readAllLines(ops.get("%"));
+            for (String d : data) {
+                for (String k : sigPlace.map.keySet()) {
+                    d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
                 }
-                sb.append(d).append("\n");
+                sb.append(d).append("\");
             }
-            sb.append("<h2>Directory Listing for "+key+"</h2>");
-            sb.append("<div class=\"folderlisting\"><a href=\"")
-            .append(key)
-            .append("..\" class=\"icon\">📁</a><a href=\"")
-            .append(key)
-            .append("..\">.. </a><a href=\"")
-            .append(key)
-            .append("..\" class=\"nounderline\">(Previous Directory)</a></div>");
-            for (Path f : map.get(key)) {
-                sb.append("<div class=\"").append((Files.isDirectory(f)?"":"")).append("\">")
-                .append("<a href=\""+(f.toAbsolutePath().toString().replace(Paths.get(OUTDIR).toAbsolutePath().toString(),""))+"\" class=\"icon\">")
-                .append((Files.isDirectory(f)?"📁":"🗎"))
-                .append("</a>")
-                .append("<a href=\""+(f.toAbsolutePath().toString().replace(Paths.get(OUTDIR).toAbsolutePath().toString(),""))+"\">")
-                .append(f.getFileName())
-                .append("</a>\t")
-                .append(Files.getLastModifiedTime(f))
-                .append("\t")
-                .append(Files.getOwner(f))
-                .append("\t")
-                .append(Files.size(f))
-                .append("</div>\n");
+            sb.append("<h2>Directory Listing for "+key+"</h2>");
+            sb.append("<div class=\"folderlisting\"><a href=\"")
+            .append(key)
+            .append("..\" class=\"icon\">&#x1F4C1;</a><a href=\"")
+            .append(key)
+            .append("..\">.. </a><a href=\"")
+            .append(key)
+            .append("..\" class=\"nounderline\">(Previous Directory)</a></div>");
+            for (Path f : map.get(key)) {
+                sb.append("<div class=\"").append((Files.isDirectory(f)?"folderlisting":"filelisting")).append("\">")
+                .append("<a href=\""+(f.toAbsolutePath().toString().replace(Paths.get(OUTDIR).toAbsolutePath().toString(),""))+"\" class=\"icon\">")
+                .append((Files.isDirectory(f)?"&#x1F4C1;":"&#x1F5CE;"))
+                .append("</a>")
+                .append("<a href=\""+(f.toAbsolutePath().toString().replace(Paths.get(OUTDIR).toAbsolutePath().toString(),""))+"\">")
+                .append(f.getFileName())
+                .append("</a>\")
+                .append(Files.getLastModifiedTime(f))
+                .append("\")
+                .append(Files.getOwner(f))
+                .append("\")
+                .append(Files.size(f))
+                .append("</div>\");
             }
-            for (String d : data2) {
-                for (String k : sigPlace.map.keySet()) {
-                    d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
+            for (String d : data2) {
+                for (String k : sigPlace.map.keySet()) {
+                    d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
                 }
-                sb.append(d).append("\n");
+                sb.append(d).append("\");
             }
-            Path newf = Files.write(Paths.get(OUTDIR,key,DIRECTORYLISTING_FILENAME),sb.toString().getBytes());
-            System.out.println("  Added info for ("+map.size()+") files to "+newf.toAbsolutePath());
+            Path newf = Files.write(Paths.get(OUTDIR,key,DIRECTORYLISTING_FILENAME),sb.toString().getBytes());
+            System.out.println("  Added info for ("+map.size()+") files to "+newf.toAbsolutePath());
         }
     }
-    private static boolean isArticleFile(Path f) {
-        return f.getFileName().toString().contains(".article");
+    private static boolean isArticleFile(Path f) {
+        return f.getFileName().toString().contains(".");
     }
-    private static boolean isHTMLFile(Path f) {
-        return f.getFileName().toString().contains(".html");
+    private static boolean isHTMLFile(Path f) {
+        return f.getFileName().toString().contains(".");
     }
-    private static void ExportCodeFile() {
-        try {
-            Path file = Paths.get("sigServer.java");
-            List<String> data = Files.readAllLines(file);
-            int i=0;
-            while (!data.get(i++).contains("sigServer()")&&i<data.size());
-            if (i<data.size()) {
-                Files.write(Paths.get(OUTDIR,"codeBackground"),data.subList(i, Math.min(i+40,data.size())),Charset.defaultCharset(),StandardOpenOption.CREATE,StandardOpenOption.TRUNCATE_EXISTING,StandardOpenOption.WRITE);
+    private static void ExportCodeFile() {
+        try {
+            Path file = Paths.get("sigServer.");
+            List<String> data = Files.readAllLines(file);
+            int i=0;
+            while (!data.get(i++).contains("sigServer()")&&i<data.size());
+            if (i<data.size()) {
+                Files.write(Paths.get(OUTDIR,""),data.subList(i, Math.min(i+40,data.size())),Charset.defaultCharset(),StandardOpenOption.CREATE,StandardOpenOption.TRUNCATE_EXISTING,StandardOpenOption.WRITE);
             }
-        } catch (IOException e) {
-            e.printStackTrace();
+        } catch (IOException e) {
+            e.printStackTrace();
         }
         
     }
diff --git a/out/articles/test articles/DIRECTORY_LISTING b/out/articles/test articles/DIRECTORY_LISTING
index 6680ff6..4e27e2a 100644
--- a/out/articles/test articles/DIRECTORY_LISTING	
+++ b/out/articles/test articles/DIRECTORY_LISTING	
@@ -17,12 +17,12 @@
 
 
 
-

Directory Listing for /articles/test articles/

🗎test3.article 2022-07-24T00:27:55.556297321Z niconiconii 994
-
🗎test2.article 2022-07-24T00:27:55.556297321Z niconiconii 781
-
🗎test2.article.html 2022-07-24T00:27:55.608296393Z niconiconii 1498
-
🗎test3.article.html 2022-07-24T00:27:55.608296393Z niconiconii 1711
-
🗎test1.article.html 2022-07-24T00:27:55.612296322Z niconiconii 1802
-
🗎test1.article 2022-07-24T00:27:55.560297251Z niconiconii 1085
+

Directory Listing for /articles/test articles/

🗎test1.article.html 2022-07-26T15:21:39.642960595Z codespace 1802
+
🗎test3.article 2022-07-26T15:21:39.058950225Z codespace 994
+
🗎test2.article.html 2022-07-26T15:21:39.646960666Z codespace 1498
+
🗎test3.article.html 2022-07-26T15:21:39.642960595Z codespace 1711
+
🗎test1.article 2022-07-26T15:21:39.058950225Z codespace 1085
+
🗎test2.article 2022-07-26T15:21:39.062950296Z codespace 781
diff --git a/out/articles/test articles/test1.article b/out/articles/test articles/test1.article index 540970a..7e7a894 100644 --- a/out/articles/test articles/test1.article +++ b/out/articles/test articles/test1.article @@ -1,5 +1,5 @@

A Test Title

-

+

In dolor erat, malesuada at elit cursus, convallis imperdiet turpis. Ut aliquet magna tellus, at viverra mauris ullamcorper vehicula. Nam quis urna semper magna ornare elementum sed id mauris. Suspendisse faucibus nunc ante, ac rhoncus nisl tristique sed. Vestibulum pretium odio eget scelerisque vestibulum. Aliquam viverra ex ac vestibulum interdum. Donec ligula nunc, dignissim a purus vitae, fermentum laoreet diam. Quisque nec auctor urna. Vestibulum sit amet ligula ullamcorper, congue ipsum et, accumsan ante. Phasellus fermentum, sapien nec pulvinar blandit, elit purus pretium urna, et dapibus orci urna eu metus. Nunc molestie dictum pharetra. Suspendisse luctus felis et ante tristique, vitae commodo diam porttitor. Aliquam orci eros, placerat ac justo vitae, bibendum efficitur metus. Phasellus eget bibendum mauris.

2 May 2022 10:16AM
%CONDITIONAL_EXPAND%
diff --git a/out/articles/test articles/test1.article.html b/out/articles/test articles/test1.article.html index b094135..420c747 100644 --- a/out/articles/test articles/test1.article.html +++ b/out/articles/test articles/test1.article.html @@ -18,7 +18,7 @@

A Test Title

-

+

In dolor erat, malesuada at elit cursus, convallis imperdiet turpis. Ut aliquet magna tellus, at viverra mauris ullamcorper vehicula. Nam quis urna semper magna ornare elementum sed id mauris. Suspendisse faucibus nunc ante, ac rhoncus nisl tristique sed. Vestibulum pretium odio eget scelerisque vestibulum. Aliquam viverra ex ac vestibulum interdum. Donec ligula nunc, dignissim a purus vitae, fermentum laoreet diam. Quisque nec auctor urna. Vestibulum sit amet ligula ullamcorper, congue ipsum et, accumsan ante. Phasellus fermentum, sapien nec pulvinar blandit, elit purus pretium urna, et dapibus orci urna eu metus. Nunc molestie dictum pharetra. Suspendisse luctus felis et ante tristique, vitae commodo diam porttitor. Aliquam orci eros, placerat ac justo vitae, bibendum efficitur metus. Phasellus eget bibendum mauris.

2 May 2022 10:16AM
diff --git a/out/articles/test articles/test2.article b/out/articles/test articles/test2.article index fc2d656..88a8f40 100644 --- a/out/articles/test articles/test2.article +++ b/out/articles/test articles/test2.article @@ -1,5 +1,5 @@

Another test title

-

+

Sed lobortis nisi id nunc tincidunt volutpat. Mauris cursus felis quis condimentum posuere. Pellentesque vitae dolor et justo suscipit ultrices. Integer dapibus leo id felis varius, ut volutpat massa bibendum. Quisque sed nunc arcu. In sit amet faucibus magna, non venenatis massa. Cras sed placerat risus, id consectetur est. Pellentesque in nunc dolor. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Quisque eget lorem ac urna posuere accumsan. Quisque sed imperdiet nisi.

1 May 2022 05:13AM
%CONDITIONAL_EXPAND%
diff --git a/out/articles/test articles/test2.article.html b/out/articles/test articles/test2.article.html index bf34830..8dcadea 100644 --- a/out/articles/test articles/test2.article.html +++ b/out/articles/test articles/test2.article.html @@ -18,7 +18,7 @@

Another test title

-

+

Sed lobortis nisi id nunc tincidunt volutpat. Mauris cursus felis quis condimentum posuere. Pellentesque vitae dolor et justo suscipit ultrices. Integer dapibus leo id felis varius, ut volutpat massa bibendum. Quisque sed nunc arcu. In sit amet faucibus magna, non venenatis massa. Cras sed placerat risus, id consectetur est. Pellentesque in nunc dolor. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Quisque eget lorem ac urna posuere accumsan. Quisque sed imperdiet nisi.

1 May 2022 05:13AM
diff --git a/out/articles/test articles/test3.article b/out/articles/test articles/test3.article index 964bb80..dc9fc96 100644 --- a/out/articles/test articles/test3.article +++ b/out/articles/test articles/test3.article @@ -1,5 +1,5 @@

And More

-

+

Curabitur suscipit quam tellus, non rhoncus diam vehicula in. Aliquam ut dapibus tortor. Cras accumsan arcu vel ante maximus ornare. Nam tempus fermentum leo maximus euismod. Donec vehicula pretium est a ultrices. Nunc blandit nibh lorem, nec blandit leo posuere quis. Sed mauris ligula, euismod eu aliquam vel, rhoncus eget magna. Proin eget tortor ut ligula suscipit mattis. Integer rutrum aliquet eleifend. Suspendisse leo libero, placerat nec mi id, sagittis malesuada felis. Quisque euismod ante cursus elit lobortis, eu tempus ligula condimentum. Mauris viverra metus et dignissim efficitur. Ut placerat nunc nunc, eu tempus neque ultrices nec. Suspendisse et magna risus. Phasellus in ullamcorper tortor. Sed lobortis ut mi in blandit.

30 Apr 2022 6:14PM
%CONDITIONAL_EXPAND%
diff --git a/out/articles/test articles/test3.article.html b/out/articles/test articles/test3.article.html index 625391b..d607ce7 100644 --- a/out/articles/test articles/test3.article.html +++ b/out/articles/test articles/test3.article.html @@ -18,7 +18,7 @@

And More

-

+

Curabitur suscipit quam tellus, non rhoncus diam vehicula in. Aliquam ut dapibus tortor. Cras accumsan arcu vel ante maximus ornare. Nam tempus fermentum leo maximus euismod. Donec vehicula pretium est a ultrices. Nunc blandit nibh lorem, nec blandit leo posuere quis. Sed mauris ligula, euismod eu aliquam vel, rhoncus eget magna. Proin eget tortor ut ligula suscipit mattis. Integer rutrum aliquet eleifend. Suspendisse leo libero, placerat nec mi id, sagittis malesuada felis. Quisque euismod ante cursus elit lobortis, eu tempus ligula condimentum. Mauris viverra metus et dignissim efficitur. Ut placerat nunc nunc, eu tempus neque ultrices nec. Suspendisse et magna risus. Phasellus in ullamcorper tortor. Sed lobortis ut mi in blandit.

30 Apr 2022 6:14PM
diff --git a/out/images/DIRECTORY_LISTING b/out/images/DIRECTORY_LISTING index 8393251..5980e01 100644 --- a/out/images/DIRECTORY_LISTING +++ b/out/images/DIRECTORY_LISTING @@ -17,7 +17,7 @@
-

Directory Listing for /images/

🗎Love_Live!_Logo.png 2022-07-23T18:15:55.635107Z niconiconii 12167
+

Directory Listing for /images/

🗎Love_Live!_Logo.png 2022-07-26T15:15:09.668054Z codespace 12167
diff --git a/out/otherpage.html b/out/otherpage.html index 0b22f0f..774f226 100644 --- a/out/otherpage.html +++ b/out/otherpage.html @@ -18,989 +18,11 @@
This is a different webpage.
- -

Welcome to SigPlace!

-

- This is a SigPlace article! It will contain information that is important (probably) and will be layed out as such. -

-

- Paragraphs are automatically split up for readability and generated correctly via the parser. There's quite a bit of flexibility with the system and makes it easy to post updates should they be required. -

-

- A lot of content management systems would do this by having a web interface and submitting content and managing it that way, but by coding my own management system and using the built-in OS' filesystem to handle the work, I save myself a lot of pains and headaches. -

-

- Lorem ipsum dolor sit amet, consectetur adipiscing elit. In feugiat, urna ut sollicitudin luctus, nulla magna faucibus mauris, at semper nisl nisi ut mauris. Vestibulum cursus tortor velit, ut congue ex porta in. Nullam hendrerit risus sit amet neque euismod faucibus. Sed ac diam non lectus euismod pulvinar eu non mauris. Donec accumsan nisl efficitur, sodales lectus et, finibus quam. Sed vel consectetur leo. Cras ut condimentum quam. Aliquam molestie viverra congue. Donec scelerisque nibh ac nulla dictum semper. Aliquam id massa a massa bibendum finibus id ac sapien. Integer vitae ullamcorper enim, non semper massa. -

-
-

-Proin cursus sodales elit, vitae volutpat mi fermentum a. In vitae magna quis leo cursus accumsan id facilisis purus. Vestibulum accumsan iaculis turpis eu sollicitudin. Sed ultricies felis non elit suscipit interdum. Maecenas sollicitudin turpis justo, vel pretium sapien scelerisque eget. Nullam sagittis finibus risus ut aliquam. Praesent quam orci, dapibus ut ex ac, sodales dapibus nunc. -

-
-

-Fusce magna risus, iaculis non justo sit amet, semper sodales urna. Morbi eu eros lectus. Integer euismod venenatis eros a hendrerit. Nulla ultricies lectus nec quam condimentum fermentum. Quisque a turpis vitae orci pharetra ullamcorper. Nunc fringilla vitae nunc a aliquam. In aliquam gravida massa. Sed imperdiet dignissim sapien, ullamcorper rutrum lacus convallis ut. -

-
-

-Nunc tortor sem, dapibus mattis varius id, varius eu leo. Phasellus efficitur nulla a diam faucibus, id facilisis lacus malesuada. Nulla condimentum egestas erat a fermentum. Ut interdum dui id est condimentum, vel fermentum nisi ornare. Sed eu rhoncus magna, sit amet finibus eros. In a nibh tincidunt, suscipit tellus eleifend, faucibus mauris. Vestibulum sagittis nisi et efficitur ullamcorper. Donec sodales efficitur ligula id congue. Etiam egestas tristique interdum. Mauris at massa eget metus pellentesque fermentum nec non lacus. Nulla turpis nunc, feugiat vel euismod ac, maximus id est. Praesent cursus elit ac dolor hendrerit lacinia. -

-
-

-Vestibulum laoreet lorem consequat, mollis augue finibus, luctus libero. Praesent convallis sed velit vitae molestie. Vestibulum nec fringilla tellus, non dictum nulla. Donec tempor ac diam sit amet porta. Quisque mi ex, vulputate ac tincidunt vel, vestibulum vitae orci. Duis gravida mauris eget mauris pulvinar, lobortis tincidunt neque efficitur. Nunc blandit metus vitae faucibus vulputate. Curabitur rhoncus volutpat lorem, sit amet pulvinar ipsum. Fusce ultricies enim odio, a viverra quam tincidunt quis. Aliquam sollicitudin a sapien id efficitur. Proin at finibus elit, id gravida elit. Nulla facilisi. Ut tincidunt, ligula eu pulvinar dapibus, lorem nisl facilisis tellus, in ornare quam dolor quis libero. Pellentesque ut convallis orci. Donec volutpat nunc velit, tristique convallis purus lacinia sit amet. Maecenas porttitor cursus nisl sed porta. -

-
-
Hello there! You can see this is the Love Live logo indeed! It is quite smol right now but that's okay. Let's keep on going with the text. If the caption is really long and with commas, they will now be combined,,,,,see how that works? Amazing!
-

-Here we demonstrate the love live logo. But wait, it's literally like in the middle wtf is going on.Here we demonstrate the love live logo. But wait, it's literally like in the middle wtf is going on.Here we demonstrate the love live logo. But wait, it's literally like in the middle wtf is going on. -

-
- - - - - - - - - - - - - - - - -
- -
- - - - - - - - -
- -
- - -
- - - - - - - - - - - - - - - -
- - - - - - - - - - - - - - - -
- - - - - -
- - - - - - - - - -
- - - - - - - - -
- -
- -
- - - - - - - - - -
- -
- - - - - -
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- -
- - - -
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

-

-import java.io.IOException;
-import java.nio.charset.Charset;
-import java.nio.file.CopyOption;
-import java.nio.file.Files;
-import java.nio.file.Path;
-import java.nio.file.Paths;
-import java.nio.file.StandardCopyOption;
-import java.nio.file.StandardOpenOption;
-import java.util.AbstractMap;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.Iterator;
-import java.util.List;
-import java.util.Map;
-import java.util.regex.Pattern;
-public class sigPlace {
-    final static String ROOTDIR = "sitefiles";
-    final static String REFDIR = "ref";
-    final static String OUTDIR = "out";
-    final static String ARTICLESDIR = "articles";
-    final static String UPLOADSDIR = "uploads";
-    final static String COMMENTSDIR = "comments";
-    final static String DIRECTORYLISTING_FILENAME = "DIRECTORY_LISTING";
-    static int PORT = 8080;
-    static double COLOR_ROTATION = 0;
-    static boolean inCodeBlock = false;
-    static String storedCodeBlock = "";
-    final static HashMap<String,String> map = new HashMap<>(Map.ofEntries(
-        new AbstractMap.SimpleEntry<>("$SITENAME", "SigPlace"),
-        new AbstractMap.SimpleEntry<>("$SITE_BACKCOL", "#111"),
-        new AbstractMap.SimpleEntry<>("$TITLE_CONTENT_START", "<div class=\"contentWrapper\"><h1>"),
-        new AbstractMap.SimpleEntry<>("$TITLE_CONTENT_END", "</h1><div class=\"content\" %ID%>"),
-        new AbstractMap.SimpleEntry<>("$CONTENT_END", "</div>"),
-        new AbstractMap.SimpleEntry<>("$DATE_CONTENT_START", "<div class=\"datebar\"></div><div class=\"date\">")
-    ));
-    final static HashMap<String,Path> ops = new HashMap<>(Map.ofEntries(
-        new AbstractMap.SimpleEntry<>(
-            "%DEFAULT", Paths.get(REFDIR,"DEFAULT.html")),
-        new AbstractMap.SimpleEntry<>(
-            "%FOOTER", Paths.get(REFDIR,"FOOTER.html"))
-    ));
-    public static void main(String[] args) {
-        if (args.length>0&&args.length%2==0) {
-            int i=0;
-            while (i<args.length) {
-                String arg1=args[i];
-                String arg2=args[i+1];
-                i+=2;
-                if (arg1.equals("-p")) {
-                    PORT=Integer.parseInt(arg2);
-                    System.out.println("Port set to "+PORT+".");
-                } else {
-                    System.err.println("Invalid argument \""+arg1+"\".");
-                    return;
-                }
-            }
-        }
-        System.out.println("Copying files over to output directory...");
-        try {
-            copyDirectory("sitefiles","out");
-            Iterator<Path> items = Files.walk(Paths.get("out")).filter((p)->!p.toAbsolutePath().toString().contains("images/")).iterator();
-            ParseArticleFiles(items);
-            items = Files.walk(Paths.get("out")).iterator();
-            ConvertArticleReferences(items);
-            items = Files.walk(Paths.get("out","articles")).iterator();
-            GenerateArticleFiles(items);
-        }catch (IOException e) {
-            e.printStackTrace();
-            System.err.println("Copying files over failed!");
-            return;
-        }
-        System.out.println("Building directory listings...");
-        try {
-            buildDirectoryListings();
-        } catch (IOException e) {
-            e.printStackTrace();
-            System.err.println("Failed to build directory listings!");
-            return;
-        }
-        System.out.println("Site has been built into the "+OUTDIR+" directory.");
-        ExportCodeFile();
-        System.out.println("\nStarting web server...");
-        new sigServer();
-    }
-    private static void ParseArticleFiles(Iterator<Path> items) {
-        while (items.hasNext()) {
-            Path f = items.next();
-            System.out.println(" Found "+f.getFileName());
-            if (Files.isRegularFile(f)) {
-                try {
-                    System.out.println("  Preparing "+f.getFileName());
-                    List<String> content = Files.readAllLines(f);
-                    if (isHTMLFile(f)) {
-                        content.addAll(0,Files.readAllLines(ops.get("%DEFAULT")));
-                        content.addAll(Files.readAllLines(ops.get("%FOOTER")));
-                    }
-                    System.out.println("  Parsing "+f.getFileName());
-                    for (int i=0;i<content.size();i++) {
-                        String s = content.get(i);
-                        //System.out.println(s);
-                        if (s.length()>0&&(isHTMLFile(f)||isArticleFile(f))) {
-                            if (!inCodeBlock) {
-                                if (s.contains("<pre>")) {
-                                    //System.out.println("Inside <pre>");
-                                    inCodeBlock=true;
-                                    storedCodeBlock="";
-                                    s=s.substring(0,s.indexOf("<pre>"));
-                                }
-                            }
-                            if (inCodeBlock&&s.contains("</pre>")) {
-                                inCodeBlock=false;
-                                boolean keyword=false;
-                                boolean inString=false;
-                                boolean inChar=false;
-                                boolean canBeNumericalConstant=false;
-                                int lengthOfConstant=0;
-                                storedCodeBlock+=s.substring(0,s.indexOf("</pre>"));
-                                storedCodeBlock=storedCodeBlock.replaceAll(Pattern.quote("<"),"<");
-                                s+="</pre>";
-                                storedCodeBlock="<pre>"+storedCodeBlock;
-                                int startPos=0;
-                                String endText=s.substring(s.indexOf("</pre>")+"</pre>".length(),s.length());
-                                s="";
-                                for (int j=0;j<storedCodeBlock.length();j++) {
-                                    if (storedCodeBlock.charAt(j)=='"') {
-                                        inString=!inString;
-                                        if (inString) {
-                                            s+=SPAN("")+"\"";
-                                        } else {
-                                            s+="\"</span>";
-                                            startPos=j+1;
-                                        }
-                                    } else
-                                    if (!inString&&!inChar) {
-                                        if (canBeNumericalConstant&&validNumericalConstantCharacters(lengthOfConstant, j)) {
-                                            lengthOfConstant++;
-                                            System.out.println("Length of Constant now "+lengthOfConstant);
-                                        }
-                                        if (canBeNumericalConstant&&lengthOfConstant>0&&!(validNumericalConstantCharacters(lengthOfConstant, j))) {
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            //System.out.println("Setting "+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j));
-                                            lengthOfConstant=0;
-                                            canBeNumericalConstant=false;
-                                            startPos=j+1;
-                                        } else
-                                        if (!canBeNumericalConstant&&storedCodeBlock.charAt(j)=='.') {
-                                            //Previous section was a member.
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else 
-                                        if (j>3&&storedCodeBlock.substring(j-3,j+1).equals("true")&&!isAlphanumeric(j-4)&&!isAlphanumeric(j+1)) {
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j)+"</span>";
-                                            startPos=j+1;
-                                        } else 
-                                        if (j>4&&storedCodeBlock.substring(j-4,j+1).equals("false")&&!isAlphanumeric(j-5)&&!isAlphanumeric(j+1)) {
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j)+"</span>";
-                                            startPos=j+1;
-                                        } else 
-                                        if (storedCodeBlock.charAt(j)=='(') {
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else 
-                                        if (j>0&&isAlphanumeric(j-1) && storedCodeBlock.charAt(j)==' '&&storedCodeBlock.charAt(j-1)!=' ') {
-                                            //Previous section was a keyword.
-                                            keyword=true;
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else 
-                                        if (j>0&&isAlphanumeric(j-1) && (storedCodeBlock.charAt(j)==';'||storedCodeBlock.charAt(j)==':')) {
-                                            //Previous section was a keyword.
-                                            //keyword=true;
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else 
-                                        if (keyword&&!(storedCodeBlock.charAt(j)>='0'&&storedCodeBlock.charAt(j)<='9'||storedCodeBlock.charAt(j)>='A'&&storedCodeBlock.charAt(j)<='Z'||storedCodeBlock.charAt(j)>='a'&&storedCodeBlock.charAt(j)<='z'||storedCodeBlock.charAt(j)==' ')) {
-                                            keyword=false;
-                                            s+=SPAN("")+storedCodeBlock.substring(startPos,j)+"</span>"+storedCodeBlock.charAt(j);
-                                            startPos=j+1;
-                                        } else
-                                        if (!isAlphanumeric(j)){
-                                            if (startPos<j) {
-                                                s+=storedCodeBlock.substring(startPos,j)+storedCodeBlock.charAt(j);
-                                            } else {
-                                                s+=storedCodeBlock.charAt(j);
-                                            }
-                                            startPos=j+1;
-                                        }
-                                    } else {
-                                        s+=storedCodeBlock.charAt(j);
-                                        startPos=j+1;
-                                    }
-                                    if (canBeNumericalConstant&&lengthOfConstant==0&&!(storedCodeBlock.charAt(j)>='0'&&storedCodeBlock.charAt(j)<='9')) {
-                                        canBeNumericalConstant=false;
-                                    }
-                                    if (!canBeNumericalConstant&&!isAlphanumeric(j)) {
-                                        canBeNumericalConstant=true;
-                                        lengthOfConstant=0;
-                                        System.out.println("Found "+storedCodeBlock.charAt(j)+", can be numeric...");
-                                    }
-                                }
-                                s+=endText;
-                                //System.out.println("Stored code block: "+storedCodeBlock);
-                            } else 
-                            if (inCodeBlock) {
-                                storedCodeBlock+=s+"\";
-                                s=" ";
-                            }
-                        }
-                        if (s.length()>0&&isArticleFile(f)) {
-                            //Check for markdown pieces.
-                            if (s.charAt(0)=='-') {
-                                //Start of a title piece.
-                                s=s.replace("-",map.get("$TITLE_CONTENT_"));
-                                s=s+map.get("$TITLE_CONTENT_").replace("%ID%","id=\"content_"+f+"\"");
-                                //Use ⤈ if there's more text to be shown than can fit.
-                            } else
-                            if (s.contains("===")) {
-                                s=map.get("$CONTENT_")+map.get("$DATE_CONTENT_")+s.replace("===","")+map.get("$CONTENT_")+"%CONDITIONAL_EXPAND%"+map.get("$CONTENT_");
-                            } else 
-                            if (s.charAt(0)==':') {
-                                //Image with caption.
-                                //Format:
-                                //:<url>,<left|right|center>,<width>,<caption>
-                                String[] splitter = s.split(Pattern.quote(","));
-                                StringBuilder captionText = new StringBuilder(splitter[3]);
-                                for (int j=4;j<splitter.length;j++) {
-                                    captionText.append(",").append(splitter[j]);
-                                }
-                                s="<div><figure style=\"text-align:center;"+((splitter[1].equals("left")||splitter[1].equals("right"))?"width:"+splitter[2]+"%;float:"+splitter[1]+";":"")+"\"><img src=\"/"+splitter[0].substring(1)+"\" style=\"margin:auto;width:100%;\"><figcaption>"+captionText.toString()+"</figcaption></figure></div>";
-                            } else {
-                                //It's regular content, so add paragraphs.
-                                s="<p class=\"color"+(((int)(COLOR_ROTATION=(COLOR_ROTATION+0.4)%6))+1)+"\">"+s+"</p>";
-                            }
-                        } else 
-                        if (s.length()==0&&isArticleFile(f)) {
-                            s="<br/>"; //Setup a line break here.
-                        }
-                        for (String key : map.keySet()) {
-                            s=s.replaceAll(Pattern.quote(key),map.get(key));
-                        }
-                        content.set(i,s);
-                    }
-                    System.out.println("  Writing to "+f.toAbsolutePath());
-                    Files.write(f, content, Charset.defaultCharset(),StandardOpenOption.CREATE,StandardOpenOption.TRUNCATE_EXISTING,StandardOpenOption.WRITE);
-                    
-                    System.out.println(" "+f.getFileName() + " conversion complete!");
-                } catch (IOException e) {
-                    e.printStackTrace();
-                }
-            }
-        }
-    }
-    private static boolean validNumericalConstantCharacters(int lengthOfConstant, int j) {
-        return storedCodeBlock.charAt(j)>='0'&&storedCodeBlock.charAt(j)<='9'||lengthOfConstant>0&&storedCodeBlock.charAt(j)=='.'||lengthOfConstant>0&&storedCodeBlock.charAt(j)>='A'&&lengthOfConstant>0&&storedCodeBlock.charAt(j)<='F'||lengthOfConstant>0&&storedCodeBlock.charAt(j)>='a'&&lengthOfConstant>0&&storedCodeBlock.charAt(j)<='f'||lengthOfConstant>0&&storedCodeBlock.charAt(j)=='x'||lengthOfConstant>0&&storedCodeBlock.charAt(j)=='X';
-    }
-    private static boolean isAlphanumeric(int j) {
-        return storedCodeBlock.charAt(j)>='0'&&storedCodeBlock.charAt(j)<='9'||storedCodeBlock.charAt(j)>='A'&&storedCodeBlock.charAt(j)<='Z'||storedCodeBlock.charAt(j)>='a'&&storedCodeBlock.charAt(j)<='z';
-    }
-    /**
-     * Writes a span tag with the included class.
-     * **/
-    private static String SPAN(String className) {
-        return "<span class=\""+className+"\">";
-    }
-    private static void GenerateArticleFiles(Iterator<Path> items){
-        System.out.println(" Generating article files...");
-        while (items.hasNext()) {
-            Path f = items.next();
-            try {
-                if (Files.isRegularFile(f)&&isArticleFile(f)) {
-                    System.out.println("  Creating article for "+f.getFileName());
-                    List<String> content = Files.readAllLines(f);
-                    List<String> preContent = Files.readAllLines(ops.get("%"));
-                    List<String> postContent = Files.readAllLines(ops.get("%"));
-                    StringBuilder sb = new StringBuilder();
-                    for (String d : preContent) {
-                        for (String k : sigPlace.map.keySet()) {
-                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
-                        }
-                        sb.append(d).append("\");
-                    }
-                    for (String d : content) {
-                        for (String k : sigPlace.map.keySet()) {
-                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
-                        }
-                        d=d.replaceFirst("div class=\"content\"","div class=\"expandedContent\"");
-                        d=d.replaceFirst("%CONDITIONAL_EXPAND%","");
-                        sb.append(d).append("\");
-                    }
-                    for (String d : postContent) {
-                        for (String k : sigPlace.map.keySet()) {
-                            d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
-                        }
-                        sb.append(d).append("\");
-                    }
-                    Files.write(Paths.get(f.getParent().toString(),f.getFileName()+"."),sb.toString().getBytes());
-                }
-            } catch (IOException e) {
-                e.printStackTrace();
-            }
-        }
-    }
-    private static void ConvertArticleReferences(Iterator<Path> items) {
-        while (items.hasNext()) {
-            Path f = items.next();
-            System.out.println(" Looking for Article References..."+f.getFileName());
-            boolean articleJavascriptIncluded=false;
-            if (Files.isRegularFile(f)&&isHTMLFile(f)) {
-                System.out.println("  Searching "+f.getFileName());
-                try {
-                    List<String> content = Files.readAllLines(f);
-                    for (int i=0;i<content.size();i++) {
-                        String s = content.get(i);
-                        if (s.length()>0&&s.contains("$ARTICLE_")) {
-                            String article = ARTICLESDIR+"/"+s.replace("$ARTICLE_PREVIEW ","")+".";
-                            System.out.println("   Found article preview request in "+f.getFileName()+" for article "+article+".");
-                            Path file = Paths.get(OUTDIR,article);
-                            List<String> newData = Files.readAllLines(file);
-                            if (newData.size()>0) {
-                                content.set(i,newData.get(0));
-                                for (int j=1;j<newData.size();j++) {
-                                    content.add(i+j, newData.get(j));
-                                }
-                                String lastline=content.get(i+newData.size()-1);
-                                lastline=lastline.replace("%CONDITIONAL_EXPAND%","<div class=\"unexpanded\" id=\"expand_"+i+"\" onClick=\"expand(this,'"+Paths.get(OUTDIR,article.toString())+"')\"><br/><br/><br/><br/>&#x2908; Click to expand.</div>");
-                                content.set(i+newData.size()-1,lastline);//<div class=\"unexpanded\" id=\"expand_"+i+"\" onClick=\"expand("+i+")\"><br/><br/><br/><br/>⤈ Click to expand.</div>");
-                            } else {
-                                content.set(i,"");
-                            }
-                            if (!articleJavascriptIncluded) {
-                                List<String> articlejs = Files.readAllLines(Paths.get(REFDIR,"article.js"));
-                                for (int j=articlejs.size()-1;j>=0;j--) {
-                                    content.add(i,articlejs.get(j));
-                                }
-                                articleJavascriptIncluded=true;
-                            }
-                        }
-                    }
-                    Files.write(f,content);
-                } catch (IOException e) {
-                    e.printStackTrace();
-                }
-            }
-        }
-    }
-    static void copyDirectory(String sourceDirectoryLocation, String destinationDirectoryLocation) 
-    throws IOException {
-        Files.walk(Paths.get(sourceDirectoryLocation))
-        .forEach(source -> {
-            Path destination = Paths.get(destinationDirectoryLocation, source.toString()
-                .substring(sourceDirectoryLocation.length()));
-            try {
-                if (Files.isDirectory(destination)) {
-                    Files.createDirectories(destination);
-                } else {
-                    Files.copy(source, destination, new CopyOption[]{StandardCopyOption.COPY_ATTRIBUTES,StandardCopyOption.REPLACE_EXISTING});
-                }
-            } catch (IOException e) {
-                e.printStackTrace();
-            }
-        });
-    }
-    static void buildDirectoryListings() 
-    throws IOException {
-        String startingPath=Paths.get(sigPlace.OUTDIR).toAbsolutePath().toString();
-        HashMap<String,List<Path>> map = new HashMap<>();
-        Iterator<Path> it = Files.walk(Paths.get(sigPlace.OUTDIR)).iterator();
-        map.put("/",new ArrayList<Path>());
-        while (it.hasNext()) {
-            Path f = it.next();
-            if (!f.getFileName().toString().equals(OUTDIR)) {
-                String myKey = f.toAbsolutePath().toString().replace(startingPath,"").replace(f.getFileName().toString(),"");
-                //System.out.println(myKey+","+f);
-                map.putIfAbsent(myKey,new ArrayList<Path>());
-                map.get(myKey).add(f);
-            }
-        }
-        System.out.println("Directory structure determined:");
-        System.out.println("    "+map);
-        for (String key : map.keySet()) {
-            System.out.println("Creating directory listing for "+key+"...");
-            StringBuilder sb = new StringBuilder("");
-            List<String> data = Files.readAllLines(ops.get("%DEFAULT"));
-            List<String> data2 = Files.readAllLines(ops.get("%FOOTER"));
-            for (String d : data) {
-                for (String k : sigPlace.map.keySet()) {
-                    d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
-                }
-                sb.append(d).append("\n");
-            }
-            sb.append("<h2>Directory Listing for "+key+"</h2>");
-            sb.append("<div class=\"folderlisting\"><a href=\"")
-            .append(key)
-            .append("..\" class=\"icon\">📁</a><a href=\"")
-            .append(key)
-            .append("..\">.. </a><a href=\"")
-            .append(key)
-            .append("..\" class=\"nounderline\">(Previous Directory)</a></div>");
-            for (Path f : map.get(key)) {
-                sb.append("<div class=\"").append((Files.isDirectory(f)?"":"")).append("\">")
-                .append("<a href=\""+(f.toAbsolutePath().toString().replace(Paths.get(OUTDIR).toAbsolutePath().toString(),""))+"\" class=\"icon\">")
-                .append((Files.isDirectory(f)?"📁":"🗎"))
-                .append("</a>")
-                .append("<a href=\""+(f.toAbsolutePath().toString().replace(Paths.get(OUTDIR).toAbsolutePath().toString(),""))+"\">")
-                .append(f.getFileName())
-                .append("</a>\t")
-                .append(Files.getLastModifiedTime(f))
-                .append("\t")
-                .append(Files.getOwner(f))
-                .append("\t")
-                .append(Files.size(f))
-                .append("</div>\n");
-            }
-            for (String d : data2) {
-                for (String k : sigPlace.map.keySet()) {
-                    d=d.replaceAll(Pattern.quote(k),sigPlace.map.get(k));
-                }
-                sb.append(d).append("\n");
-            }
-            Path newf = Files.write(Paths.get(OUTDIR,key,DIRECTORYLISTING_FILENAME),sb.toString().getBytes());
-            System.out.println("  Added info for ("+map.size()+") files to "+newf.toAbsolutePath());
-        }
-    }
-    private static boolean isArticleFile(Path f) {
-        return f.getFileName().toString().contains(".article");
-    }
-    private static boolean isHTMLFile(Path f) {
-        return f.getFileName().toString().contains(".html");
-    }
-    private static void ExportCodeFile() {
-        try {
-            Path file = Paths.get("sigServer.java");
-            List<String> data = Files.readAllLines(file);
-            int i=0;
-            while (!data.get(i++).contains("sigServer()")&&i<data.size());
-            if (i<data.size()) {
-                Files.write(Paths.get(OUTDIR,"codeBackground"),data.subList(i, Math.min(i+40,data.size())),Charset.defaultCharset(),StandardOpenOption.CREATE,StandardOpenOption.TRUNCATE_EXISTING,StandardOpenOption.WRITE);
-            }
-        } catch (IOException e) {
-            e.printStackTrace();
-        }
-        
-    }
-}
-
-

-
3 May 2022 10:25AM




⤈ Click to expand.
-

A Test Title

-

- In dolor erat, malesuada at elit cursus, convallis imperdiet turpis. Ut aliquet magna tellus, at viverra mauris ullamcorper vehicula. Nam quis urna semper magna ornare elementum sed id mauris. Suspendisse faucibus nunc ante, ac rhoncus nisl tristique sed. Vestibulum pretium odio eget scelerisque vestibulum. Aliquam viverra ex ac vestibulum interdum. Donec ligula nunc, dignissim a purus vitae, fermentum laoreet diam. Quisque nec auctor urna. Vestibulum sit amet ligula ullamcorper, congue ipsum et, accumsan ante. Phasellus fermentum, sapien nec pulvinar blandit, elit purus pretium urna, et dapibus orci urna eu metus. Nunc molestie dictum pharetra. Suspendisse luctus felis et ante tristique, vitae commodo diam porttitor. Aliquam orci eros, placerat ac justo vitae, bibendum efficitur metus. Phasellus eget bibendum mauris. -

-
2 May 2022 10:16AM




⤈ Click to expand.
-

Another test title

-

- Sed lobortis nisi id nunc tincidunt volutpat. Mauris cursus felis quis condimentum posuere. Pellentesque vitae dolor et justo suscipit ultrices. Integer dapibus leo id felis varius, ut volutpat massa bibendum. Quisque sed nunc arcu. In sit amet faucibus magna, non venenatis massa. Cras sed placerat risus, id consectetur est. Pellentesque in nunc dolor. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Quisque eget lorem ac urna posuere accumsan. Quisque sed imperdiet nisi. -

-
1 May 2022 05:13AM




⤈ Click to expand.
-

And More

-

- Curabitur suscipit quam tellus, non rhoncus diam vehicula in. Aliquam ut dapibus tortor. Cras accumsan arcu vel ante maximus ornare. Nam tempus fermentum leo maximus euismod. Donec vehicula pretium est a ultrices. Nunc blandit nibh lorem, nec blandit leo posuere quis. Sed mauris ligula, euismod eu aliquam vel, rhoncus eget magna. Proin eget tortor ut ligula suscipit mattis. Integer rutrum aliquet eleifend. Suspendisse leo libero, placerat nec mi id, sagittis malesuada felis. Quisque euismod ante cursus elit lobortis, eu tempus ligula condimentum. Mauris viverra metus et dignissim efficitur. Ut placerat nunc nunc, eu tempus neque ultrices nec. Suspendisse et magna risus. Phasellus in ullamcorper tortor. Sed lobortis ut mi in blandit. -

-
30 Apr 2022 6:14PM




⤈ Click to expand.
-

Curabitur vel tempus ex

-

-Curabitur vel tempus ex. Duis cursus sapien nisl, ut pulvinar dui porttitor ut. Nullam odio purus, tristique non turpis sit amet, malesuada ultricies purus. Mauris ut nulla nisl. Aenean sit amet est egestas justo volutpat consequat. Suspendisse in sagittis augue, et mattis tortor. Nullam viverra metus et nibh fringilla iaculis. -

-
- - -

-

-<><Test>"</test></test2><test3>"
-            
-

-
29 Apr 2022 7:37PM




⤈ Click to expand.
+$ARTICLE_PREVIEW sigplace1 +$ARTICLE_PREVIEW test articles/test1 +$ARTICLE_PREVIEW test articles/test2 +$ARTICLE_PREVIEW test articles/test3 +$ARTICLE_PREVIEW curabitur vel tempus ex
diff --git a/sigPlace.class b/sigPlace.class deleted file mode 100644 index 4976b83..0000000 Binary files a/sigPlace.class and /dev/null differ diff --git a/sigPlace.java b/sigPlace.java index a97e1a1..716b6f3 100644 --- a/sigPlace.java +++ b/sigPlace.java @@ -127,6 +127,7 @@ public class sigPlace { inCodeBlock=false; boolean keyword=false; boolean inString=false; + char stringChar=' '; boolean inChar=false; boolean canBeNumericalConstant=false; int lengthOfConstant=0; @@ -137,9 +138,10 @@ public class sigPlace { String endText=s.substring(s.indexOf("
")+"
".length(),s.length()); s=""; for (int j=0;j"; @@ -210,7 +212,7 @@ public class sigPlace { if (!canBeNumericalConstant&&!isAlphanumeric(j)) { canBeNumericalConstant=true; lengthOfConstant=0; - System.out.println("Found "+storedCodeBlock.charAt(j)+", can be numeric..."); + //System.out.println("Found "+storedCodeBlock.charAt(j)+", can be numeric..."); } } for (int j=0;j