Skip to content

Latest commit

 

History

History
 
 

hw4-contributing

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 

giving back to the open source community

requirements

For this assignment, you must give something back to the open source community. There are two ways you can do this: create your own project, or add documentation to an existing project.

your own project

If you have an idea you want to develop, now's your chance! It can be about anything you want. I'll help you spiffy it up and distribute it to the open source community.

Here's some projects previous cs100 students have created:

  • Henry Garcia and Daniel Ramirez created the git game: a game to help people learn git commands; this was really popular, and I think a sequel covering some more advanced features of git would be a huge success

  • Jamal Moon created PacVim: a game to help people learn vim commands

  • Thomas Liu and Adam Chao created regexProgram: a tutorial to help students learn regular expression programming

  • Rica Feng and Stanley Cohen's Melody Matcher: a game for improving your tone recognition

adding documentation

One common problem with open source software is a lack of documentation and easily accessible tutorials. You will create some. Future students of this class (and random strangers on the internet) will be using your tutorials to help them learn. Your tutorial should be between 1000-2000 words. It should have plenty of code examples and/or pictures illustrating your topic.

You are free to choose any topic that will be interesting to future cs100 students. Here are some past assignments and some suggestions for extending their work:

Some other ideas are:

  • Think of a topic that initially confused you, and explain it in a way that makes sense to you. This will help future students master the topic.

  • Pick one of the labs in this course and improve it.

  • Create an entirely new lab on a topic that you wish you had more practice with.

  • Pick a writeup that already exists within the repo and improve it somehow. This may entail a complete rewrite of the entire thing.

writing style

Your writeup must be FUN and ENGAGING. Informal writing is encouraged. Imagine your favorite internet blog post and write like that. A short, clear writeup is MUCH better than a long wordy writeup.

In particular, don't write long, drawn-out sentences that use sophisticated verbiage because no one wants to read that, especially not cs100 students or random programmers on the internet be kind to us oh and use proper punctuation because reading this sentence totally sucks. Also, spll chck ur writing and dnt use txt spk b/c I hate tht 5|-|!7. (Translation: spell check your writing and don't use text speak because I hate that ****.)

I highly recommend you visit UCR's writing center. If you do, I will give you +5 points of extra credit.

collaboration policy

You may work in a team on this assignment, or you may work individually. Teams can be of any size, but a larger team must give a larger contribution. If you choose a topic that overlaps with someone else, I will assign you to the same team.

You are ENCOURAGED to discuss this assignment with anyone, whether they are on your team or not. In particular, you should get other people to read your drafts!

You must NOT copy and paste material from the internet or any other source.

You MAY use images that you did not create yourself if the use conforms to the images' licensing agreements.

submission instructions

There are three submissions for this assignment:

The first is part is due before class on Wednesday, May 06. In this submission, you must create an issue on github describing what your tutorial will be about, and who will be on your team. I will use this submission to ensure your topic is appropriate.

The second submission is due before class on Wednesday, May 20. This is a rough draft submission of your project. Create a folder in this repo called /textbook/yoursubject or put your writeup in whatever subfolder of textbook that is appropriate. You should create a pull request through github on this repo showing the current status of your project. You should be approximately 75% complete with your project's content at this point. I will use this submission to make sure that your project will actually provide benefit to future cs100 students.

Your third submission is due at midnight on Friday, June 05. This will be the final submission for your project. You must submit your tutorial as a pull request on this repository through github. Use the same folder from above. Inside the folder should be at least a file called README.md that contains the contents of your tutorial. You may include other files in this folder, such as images or cpp files, if they are relevant to the tutorial. I will evaluate the pull request the same as any other pull request into an open source project.

grading

20 points for your first draft

40 points for technical accuracy

40 points for writing style

Ultimately, grading is entirely subjective on my part. If I enjoyed reading your writeup, you will get a good score. If I don't enjoy reading it, you will get a bad score. Therefore, I recommend you show me drafts of your progress. I'll give you advice on how to make your writeup more fun.

If you visit the writing center, I will give you +5 points of extra credit on this assignment. (You'll also get a much higher grade anyways.)