GithubHelp home page GithubHelp logo

boscojwho / wikipedia-ios Goto Github PK

View Code? Open in Web Editor NEW

This project forked from wikimedia/wikipedia-ios

0.0 1.0 0.0 1.05 GB

📱The official Wikipedia iOS app.

Home Page: https://www.mediawiki.org/wiki/Wikimedia_Apps/Team/iOS

License: MIT License

Shell 0.10% JavaScript 1.70% Ruby 0.13% C 0.88% PHP 0.06% Objective-C 21.85% CSS 0.35% Swift 68.69% HTML 6.21% Less 0.02%

wikipedia-ios's Introduction

Wikipedia iOS

The official Wikipedia iOS app.

Wikipedia MIT license

Building and Running

In the directory, run ./scripts/setup. Note: going to scripts directory and running setup will not work due to relative paths.

Running scripts/setup will setup your computer to build and run the app. The script assumes you have Xcode installed already. It will install homebrew, SwiftLint, and ClangFormat. It will also create a pre-commit hook that uses ClangFormat for linting Objective-C code.

After running scripts/setup, you should be able to open Wikipedia.xcodeproj and run the app on the iOS Simulator (using the Wikipedia scheme and target). If you encounter any issues, please don't hesitate to let us know via a bug report.

Required Dependencies

If you'd rather install the development prerequisites yourself without our script:

  • Xcode - The easiest way to get Xcode is from the App Store, but you can also download it from developer.apple.com if you have an Apple ID registered with an Apple Developer account.
  • SwiftLint - We use this for linting Swift code.
  • ClangFormat - We use this for linting Objective-C code.

Contributing

Covered in the contributing document.

Development Guidelines

These are general guidelines rather than hard rules.

Coding Guidelines

Formatting

We use Xcode's default 4 space indentation and our .clang-format file with the pre-commit hook setup by scripts/setup. Where possible, our Swift code is automatically formatted by SwiftLint based on the rules defined in .swiftlint-autocorrect.yml.

Process and Code Review Norms

Covered in the process document.

Logging

When reading logs, note that the log levels are shortened to emoji.

  • 🗣️ Verbose
  • 💬 Debug
  • ℹ️ Info
  • ⚠️ Warning
  • 🚨 Error

Testing

The Wikipedia scheme is configured to execute the project's iOS unit tests, which can be run using the Cmd+U hotkey or the Product → Test menu bar action. In order for the tests to pass, the test device's language and region must be set to en-US in Settings → General → Language & Region. There is a ticket filed to update the tests to pass regardless of language and region.

Schemes and Targets

  • Wikipedia - Points to production servers.

  • Staging - Points to various staging server environments. You can adjust these environments by changing the current property of Configuration:

    • An option of appsLabsForPCS will point to the Apps team's staging environment for page content.
    • An option of betaCluster will point to the MediaWiki beta cluster environment for most API calls. This is meant to be a more blanket environment setting, so if this value exists it will also force the beta cluster environment for page content on the article view. This beta cluster environment is also where developers can test sandbox push notifications triggered across various wikis. This is selected by default.

    The Staging scheme also has our feature flags set to true. It displays features that are still in development. It is pushed to TestFlight as a separate app.

  • Experimental - For one-off builds, to demonstrate early development or prototype features. This points to production servers by default, but can be adjusted to whatever server environment is needed via temporary adjustments in Configuration. We also sometimes use it for design review, before features go through PR review. It is pushed to TestFlight as a separate app.

  • Local Page Content Service and Announcements - used by engineers in Debug-mode only. This has the ability to toggle different local environments within the current property of Configuration:

    • An option of localPCS will point to a locally running mobileapps repository for page content. This is selected by default.
    • An option of localAnnouncements will point to a locally running wikifeeds repository for the announcements endpoint. This is selected by default.
    • All other endpoints will point to production.
  • RTL - Launches the app in an RTL locale using the -AppleLocale launch argument. This is used by engineers in Debug-mode only.

  • Performance Testing - This is a duplicate scheme of Wikipedia, but uses the Release configuration in its Run step instead of Debug. We use this scheme when we manually run performance tests as a part of our pre-release checklist.

  • WMF - Bundles up the app logic shared between the main app and the extensions (widgets, notifications).

  • Update Localizations - Covered in the localization document.

  • Update Languages - For adding new Wikipedia languages or updating language configurations. Covered in the languages document.

  • {{name}}Widget, {{name}}Notification, {{name}}Stickers - Extensions for widgets, notifications, and stickers.

Continuous Integration

Covered in the CI document.

Event Logging

Covered in the event logging document.

Web Development

The article view and several other components of the app rely on web components. Instructions for working on these components are covered in the web development document.

Contact Us

If you have any questions or comments, you can email us at ios-support[at]wikimedia dot org. We'll also gladly accept any bug reports.

wikipedia-ios's People

Contributors

joewalsh avatar montehurd avatar tonisevener avatar coreyfloyd avatar bgerstle avatar staykids avatar mazevedofs avatar translatewiki avatar wmf-apps-ci avatar amrox avatar dempseyatgithub avatar bvibber avatar josve05a avatar dr0ptp4kt avatar niedzielski avatar ndis1 avatar nirzar avatar berndsi avatar julienbodet avatar bearloga avatar barbaramartina avatar mdholloway avatar jantimar avatar junholee6a avatar huayu0723 avatar deskana avatar kellyroach avatar aria1991 avatar michalciurus avatar waffleboot avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.