This is an old revision of the document!
This is a sample format for a dated entry. Please substitute the actual date for “Month Day, Year”, and duplicate the level 4 heading to make additional entries.
As an aid, feel free to use the following questions to help you generate content for your entries:
This week we continued to become familiar with the use of the UNIX commands and how to access and edit text files containing html and php content. We also dabbled with outputting php to a webstream written within the html markup.
ls – lists files
pwd – print working directory, gives absolute path
mkdir php – makes a dir called php
cd public_html – changes dir to public_html
cp – copy files
mv – moves files
rm – removes files
man ls – shows online manual for ls
Pod colors:
Text Editor: nano
To open a file and edit: nano test.html
PHP:
Text files containing php have to be saved with the .php extension Echo outputs to webstream \ escapes quotes ; necessary statement ender
Bacon salt is a thing!
This week we learned how to access Firefox from the terminal with a super easy command, firefox &. We also started loops, more specifically loops within html tables. The if statement is a condition that resolves to true or false. The numeric for, while and do while loops are condition-based, but the list-based for loop is not. It still has stuff to go through.
ctrl K – cuts current line and stores in buffer
ctrl U – uncut from cutbuffer into current line
ctrl C – displays position of cursor
ctrl A – moves to beginning of current line
ctrl E – move to end of current line
Produce a checkerboard table using a combination of PHP, HTML and CSS.
Attempt 1:
Generated a 10px border around a 480px high and wide table. The two for loops added 8 red rows and 8 black rows running side-by-side and half the length of the table. Not exactly sure why that happened but at least there was output.
Multiple Attempts:
Generated a 10px border around a 480px high and wide table with a black square in the bottom right hand corner. I used two for loops to output the table row and table columns. I then added an if, else statement to add the red and black backgrounds. It was supposed to print a checkerboard but only printed a single black square in the bottom right hand corner of the table.
Another Attempt:
Did some research and found that you need to add the rows and columns before you use an if statement to output them in checkerboard fashion.
for ($i = 1; $i <= 8; $i ++) for ($j = 1; $j<=8; $j ++) $rowcol=$i + $j;
This week we ventured into the world of arrays and functions. An array is a container. It stores multiple values in one variable. The values are accessed using an index number. In PHP, arrays have value to key associations.
There are three different types of arrays…
Multidimensional →contains one or more arrays
Indexed →has a numeric index
Syntax:
$item [0] = “mango”; $item [1] = “banana”; $item [2] = “apple”;
Associative →has named keys
Syntax:
<?php $array( key => value, key => value2, key => value3, … ); ?>
The key can be an integer or a string and one array can contain both at the same time. The value can be of any type.
Always use quotes around a string array index. e.g. $item[‘papaya’] Do not put quotes around keys that are constants or variables.
Syntax:
Function functionName( optional: parameters/arguments ) { code to be executed; }
Function names can start with letters or an underscore but NOT a number. Information is passed to the function through comma-separated arguments.
Draw a picture using PHP. See php.net’s image processing and GD documentation for help.
Using the example code done in class (function.php) I attempted to create an abstract image using rectangles and ellipses. The xy coordinates were a little baffling at first but once I confronted the documentation things seemed to make some sense. I was able to create several rectangles of varying widths and lengths and even executed a transparent ellipse using imageallocatealpha over the center of the design.
Pro tip:
Next attempt might be an homage to the square.
This week’s entry, which includes the week before break (Feb 8 – 12) we explored the vexing world of graphs. The first attempt started before break and was hampered possibly by pre-breakitis, or maybe it had something to do with arrays or lack thereof either-way it didn’t have the finesse that this weeks graph code showed.
The graph starts out with a call to the header(), which outputs an image in the form of a png file.
header("Content-type: image/png");
The variable $img stores the container parameters for the graph using php’s imagecreatetruecolor. The container is 800 x 100.
$img = imagecreatetruecolor(800, 100);
Next, we mixed some colors in our virtual palette using imagecolorallocate, which allocates a color for an image. It must be called in order to create each color used in the image represented by $img. The first call to imagecolorallocate() fills the background color in images created by imagecreate().
Because we can…we shall Foof. It. Up.
$fuschia = imagecolorallocate($img, 0xff, 0x00, 0xff);
The imageline() function does exactly what you think, it draws a line between two given points. Here we established our x-axis and y-axis lines in white on the graph.
imageline($img, 0, 0, 99, $white); // y-axis line
The fopen() function in php binds a named resource, specified by a filename, to a stream.
$fh = fopen("/home/username/public_html/php/data.txt", "r");
Here we are opening a stream to our data.txt file that contains a list of numbers used as plot points on our graph. The “r” is a mode parameter that specifies the type of access set to the stream. The “r” tells fopen to open the file with read only access.
Now we tackle the for loop(s).
First, we assign a starting point for each axis.
$x = 10; $y = 97;
Next we use fscanf() to parse input from the $fh (data.txt) file and interprets the input according to the specified format. A type specifier determines how the argument data is treated. The %d means that the argument is treated as an integer, and presented as a decimal number.
fsanf($fh, "%d", $pt); imageline($img, $x, $y, $x + 98, 100 - $pt, $blue); $x = $x + 98; $y = 100 - $pt;
This loop was created for each of the four plotted lines on the graph.
The second attempt at the vexing world of graphs yielded a cleaner, more efficient piece of code. Arrays were not fought but embraced and implemented within a nested for loop.
A color array was created ($color = array();) and added to our virtual palette.
$color[0] = $blue = imagecolorallocate($img, 0x00, 0x00, 0xff);
The first loop looped through the data series or the four rows and eight columns of numbers in our datafile.txt file.
for($i = 0; $i < 4; $i++) { $dataline = fscan($fh, "%d %d %d %d %d %d %d %d"); }
The nested for loop plots the lines on the graph using imageline and calls our color array() to plot four lines on our graph.
for($x =0; $x < 8; $x++) // loops each line { imageline($img, $px, $y, 100 * $x + 10, 99 -$dataline[$x], $color[$i]); $px = 100 * $x + 10; $y = 99 - $dataline[$x]; }
Pro tip – Don’t forget to close your file. fclose($fh);
In observance of today being a leap day (or intercalary day) here’s a fun fact that may prove useful reference in another four years.
Fact: The point of a leap year is to help adjust the Gregorian calendar to the solar calendar. A leap second adjustment is occasionally applied to Coordinated Universal Time to compensate for the fact that adding an extra day every four years doesn’t keep the two calendars aligned.
If the last two digits of the year are divisible by four then it’s a leap year. Century years are the exception to this rule. They must be divisible by 400 to be a leap year. http://www.rd.com/culture/leap-year-facts/
Enough diversions, let's continue with more PHP fun.
This week we started exploring how to use the XML (eXtensible Markup Language) parser. XML is a data format used to store and transport data on the Web. We grabbed an XML parser from the web and used it in our code to pull data from a url on the corning-cc.edu website. The variable $url = “……”; pulls the data from the page and the include(“xml2array.php”) references the parser whose contents are stored in a separate file.
Using variables, we defined the information we wanted to extract and then echoed and printed that information to the web using php.
Challenge: Star fun
Thrown out to us a while ago was a challenge to create a star using PHP. I started tinkering with this shortly after the challenge was laid down and have managed to create a five-pointed star. The bottom two points need some tweaking. Currently they expand to the bottom corners of the container, which makes the lower half of the star look disproportionate to the upper three points. I think moving both points in towards the center will help to create a better balance. Note: make these changes!
Using the imagecreatetruecolor function I created a 400 x 400 container to hold the star.
$img = imagecreatetruecolor(400, 400);
Then set the colors for each line to a different hue using imagecolorallocate.
$blue = imagecolorallocate($img, 0, 255, 153);
I did this so that as I was creating the image I would be able to easily match each line in the code to a line in the image of the star. I found keeping them all one color and bouncing between the image and the code sometimes maddening. Cutting, buffering and pasting multiple versions of the same line at once probably contributed to the confusion. To create the star I used imageline and started plotting the points by referencing the x, y coordinates of the four corners on the container. For reference the coordinates are as follows:
I also stumbled upon a line(x1, y1, x2, y2) processor from the KhanAcademy that I found useful in tinkering or fine tuning some lines.
https://www.khanacademy.org/computer-programming/linex1-y1-x2-y2-processingjs/827916099
At this point, I want to explore thickening the line weight and maybe playing with the color(s). Note: make these changes!
This is a sample format for a dated entry. Please substitute the actual date for “Month Day, Year”, and duplicate the level 4 heading to make additional entries.
As an aid, feel free to use the following questions to help you generate content for your entries:
This week we were introduced to the pod and given directions on how to open a terminal session and ssh into Lab46. To become familiar with editing our Opus project UXIO had us customize our title and subtitle in addition to adding a brief introductory statement. We also subscribed to the class mailing list and sent a brief introductory message to the class. This task familiarized us with maneuvering within the mail program Alpine. Using the IRC or class chat is still somewhat unclear but the setup went smoothly.
Don't forget to read the MOTD!
Check your Lab46 email frequently!
This weeks project (arc0) relates to archive handling. Archives are containers that encapsulate things or files. Compression is an action performed on a single file.
The tar (GNU version) command stores and extracts files from a tape or disk archive. It also combines multiple files into a singe file.
xz is a data compression tool. It compresses or decompresses a file.
gzip compresses or expands files.
zip packages and compresses (archive) files.
tac concatenates and prints files in reverse.
rev reverses lines characterwise
To decompress the .tar.xz file use the tar xf filename command in the directory you want to extract the files to. Use the tac (cat backwards) and rev commands to help unscramble the files.
Mars’ two moons are Phobos and Deimos and are named after Greek mythological characters. The Latin translation of each is fear and panic respectively.
This week we learned about pipes, filters and the file system. Actually we learned about multiple pipes but the one most pertinent to us is the | command. Pipes are extremely useful and powerful. They allow the connection of two or more commands, which allows for the output (stdout) of one element to be the input (stdin) of the next. Each pipe tells the system to connect the standard output of the left element to the standard input of the right program. Pipes are unidirectional, meaning that data flows through the pipe from left to right.
Command Expansions: back ticks/back quotes
The File System:
Dir –points to many files. Home dir mounted from the file server.
. shows current location; doesn’t change
.. parent goes up in dir; takes you to home
Project Notes
This week’s project is the legendary puzzle box (pbx0)! As soon as I solve it, I will update this section with my notes.
Fun with Vi! Enlightenment has finally come albeit with a learning curve. Let’s begin our journey into the key elements of this “cursor less” world.
To enter this world type ‘vi filename’. The screen before you is command mode where letter keys are individual commands. The second mode is insert where most of your text input happens. To enter insert from command hit the lowercase “i” key, to exit insert and enter command hit the “esc” key.
Commands follow a general pattern: [cmd] [number] textobject. Lowercase commands define a word as a contiguous sequence of digits, and underscores. Uppercase commands define a word as a contiguous sequence of non-whitespace characters. Commands can be prefixed with a number, e.g. 24h goes left 24 characters.
There are many commands in Vi that edit, navigate, and manipulate the text file. We will explore them next time.
Pro tip: Do not use cursor keys in classic Vi.
Project Notes
This week’s project is the follow up to the legendary puzzlebox (pbx0) appropriately titled puzzlebox next (pbx1). I am currently hacking my way through this labyrinth. The first challenge was opening the zipped pbx1 file, which was easily accomplished with the unzip tool. This inflated a README file and prompted for a password to an enigmatic.file file. Not having a password to open said file I sheepishly hit the enter key, which skipped the enigmatic file due to incorrect password and inflated an octal2ascii.c file. Deciding it was best to actually read the README I opened it with a text editor after establishing it was an ASCII text file. The file contained the password to the enigmatic file along with a sprinkling of hints and insights to help unravel the puzzle. With the newly acquired information I ran the unzip tool on the pbx1 file again and when prompted input the four character password. This inflated enigmatic but prompted for a password to part1, not having one I hit enter again, and watched as it skipped parts 1-4 due to an incorrect password. Running file on enigmatic revealed it was a uuencoded or xxencoded, ASCII text file. To decode it I ran uudecode and found a new file titled stage2 in my directory. This file is a regular file without any read permissions. To change the file permissions use chmod 640 or 440. After changing the permissions, stage2 is listed as an ASCII text file with no line terminators. Opening the file reveals a single line of two digit numbers and characters. To be continued…
The octal2ascii.c file is c source, ASCII text. Open in a text editor and read the comment section. The c code is a helper program that takes data from STDIN, converts it, and displays it to STDOUT. Follow the directions to compile the code using the correct file names (gcc octal2ascii.c –o octal2ascii). This creates an executable file that can be used like any other tool in your UNIX arsenal. To be continued…
In observance of today being a Leap Day, (or intercalary day) here’s a short fact that may prove useful reference in another four years.
Fun Fact:
February 30th is a thing! In the year 1712 in the countries of Sweden and Finland an extra Leap Day was added to February to align their outdated Julian calendar with the new Gregorian calendar.
Bonus Fun Fact:
February 30th is still celebrated in the mythical world J.R.R. Tolkien created in Lord of the Rings. The fantastical Hobbits observe twelve 30-day months every year, including February. http://www.rd.com/culture/leap-year-facts/
This week we time traveled in shell and learned about the history command. A full featured, useful new command that when typed at the command prompt shows all the commands entered EVER. There were so many delicious new commands that I will give a brief highlight of the more interesting ones.
At prompt:
To access process management type ‘ps’ at the command prompt and all the processes running are displayed to the screen. Task manager in windows is the equivalent.
To run cat or firefox or … in the background type ‘cat &’ at the prompt. To bring it back to the foreground type ‘fg’.
To obliterate PATH:
Project Notes:
Wpa0 or web page adventure is on task for this week’s project. Create an adventure using HTML, file permissions and styling. For the styling in-line or CSS works.
I have started this little ditty and am finding it quite fun to create. Not going to give any spoilers because the project isn’t complete and I’ve hit a creative roadblock. I will update this post as soon as I unblock and finish the adventure.