Skip to content

iosdecal/ios-decal-hw2

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

6 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Homework 2: Swifty Calculator

Due

Monday, September 25 at 11:59pm

Description

In your first homework assignment, you learned the basics of types, functions, and classes in Swift 3.0 via the Xcode Playground. Our lectures thereafter have introduced you to the MVC pattern, how to perform UI updates and seques (e.g. label.text = 'foo', pushViewController), and now you will be putting these techniques together to build a working calculator.

But, wait -- who would want to add all those buttons to the storyboard and connect them to their appropriate delegate methods? There's got to be a better way!

Thankfully, your instructors have provided the basic UI and action selectors in your project skeleton. You will be primarily responsible for writing the logic (the brains) of the calculator app.

As an added bonus, there are 4 test suites (see SwiftCalcUITests) to test your implementation. These test suites form a subset of the tests we will be using to grade your app on behavior and functionality. In order to run a test in Xcode, you can click on the ◇ button to the left of any XCTestCase, or open the Test Navigator and click the ▶ button. For more information on Unit Tests, read the documentation.

By the end of this project, you will have learned how to update UI elements in response to user interaction, the basics of the Swift 3.0 language through implementing a subset of the iOS calculator features, and the fundamentals of TDD in Xcode8.

Instructions

Create a working calculator. Note that for this project, you will be responsible for building a greedy calculator, in which all orders of operation have the same priority. In any cases of uncertainty on how to update resultLabel, follow the behavior of the iOS calculator.

1. General Requirements (See GeneralCalcUITests)

  • a. resultLabel can hold a max of 7 characters
  • b. Pressing a number button updates the resultLabel (if a user action would violate rule a, ignore that action)
  • c. resultLabel displays the correct value (the current number being entered, or the result of a calculation)
  • d. C button resets resultLabel to 0
  • e. +/- flips the sign of the input
  • f. = updates the resultLabel with the resulting calculation

2. Basic Operations (See BasicCalcUITests)

  • a. Support addition between single-digit integers
  • b. Support subtraction between single-digit integers
  • c. Support multiplication between single-digit integers
  • d. Support division between any two integers

3. Intermediate Operations (See IntermediateCalcUITests) TODO: optional?

  • a. Consecutive operations will update resultLabel as though the = button was pressed prior (after pressing the buttons [1,+,2,+] resultLabel should read 3. Then, after pressing [4, =], resultLabel should read 7)
  • b. Support successive addition and subtraction operations on integers
  • c. Support valid sequences of operations on integers (pressing [2,+, -, \, *, 3,=] should produce 6)

4. Advanced Operations (See AdvancedCalcUITests) TODO: optional?

  • a. Division produces Doubles instead of Ints where appropriate
  • b. Display an Int when the Double result is equivalent to an Int of valid size
  • c. Support the entry and operations of Decimals (see the prettyOutput computed property in BaseExtension)
  • d. (Optional) Support Scientific Notation for very large or very small results (1000000 * 25 -> 2.5e7, 9 / 4000000 -> 2.25e-6)

Other Bells & Whistles (OPTIONAL)

  1. Make the calculator look more aesthetic (update buttons styles)
  2. Add a landscape view like the iOS calculator
  3. Present an alert if user performs an invalid action (e.g. divides by zero)

Grading

Grading is primarily based on your app's functionality (as determined by the autograder). We have provided autograder test cases in the *UITests group as a way for you to test your app as you build it out. Following the specs outlined in this README will ensure you pass the remaining 3 hidden test cases. You will be given 1 point for every set of tests you passed. Note that if you don't pass Required Behaviors, your tests will fail against the autograder.

Video Demos

Integer Calculator

Screenshot

Double Calculator

Screenshot

Double Calculator with Scientific Notation

Screenshot

About

Homework 2: Swifty Calculator

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages