[[PageOutline]] = BOINC software development = BOINC is free software, distributed under the [http://www.gnu.org/copyleft/lesser.html Lesser General Public License] (LGPL). The University of California holds the copyright on all BOINC source code. By submitting contributions to the BOINC code, you irrevocably assign all right, title, and interest, including copyright and all copyright rights, in such contributions to The Regents of the University of California, who may then use the code for any purpose that it desires. == BOINC development == * [ProjectPeople Personnel and contributors] * [DevProcess Development process] * [DevProjects Development projects] * [/email_lists.php boinc_dev], an email list for BOINC developers * [CodingStyle Coding style] * [UsingSvn Using SVN] * [DebugClientWin Debugging the client on Windows] * [VersionSixPortal BOINC 6.0 Development Portal] * [WikiMeta BOINC wiki documentation] == Get and build BOINC software == * [SourceCode Get source code] * [SoftwarePrereqsUnix Software prerequisites] * [BuildSystem Building on Unix] * [PythonMysql Installing python-mysqldb] * [CompileApp Building applications] * [CompileClient Building the client] * [VirtualMachines Linux VMs for use with BOINC] == Writing add-on software == BOINC's architecture is 'open'; documented interfaces making it possible to develop various types of applications and web sites that interact with BOINC components. Examples include: * [GuiRpc Client GUIs]: Applications that control a local or remote core client. * [CreditStats Credit statistics web sites]: Web sites showing credit information (project totals, user/team/country leaderboards) based on daily XML feeds of statistics data from BOINC projects. The XML format is documented [XmlStats here]. * [AccountManagement Account managers]: Web sites that let BOINC users create and manage accounts on multiple projects. * [StatsXml Aggregate credit statistics]: Web RPCs for getting cross-project credit data for hosts, teams and users. * [WebRpc Web RPCs]: These interfaces let a program or web site obtain information about projects, and create/edit entities (users, teams, hosts) on projects. * [PrefsOverride Local editing of preferences]: This mechanism lets you write programs for local editing of preferences. Check [/addons.php the index of add-on software] before writing anything (it may already exist). The index has instructions for submitting new add-ons. == Alpha testing == * [AlphaInstructions Instructions for testers] * [ReportBugs Reporting bugs] * [/alpha/ The Alpha Test project] * [TestMatrix Alpha test matrix] == Design docs for current development == * [AdaptiveReplication Adaptive replication] * [ClientSetupWinSix Version 6 Windows installer, design] * [ClientSetupLogicWinSix Version 6 Windows installer, implementation] * [PythonAppDev Python-based simplified app development] * [LowLatency Low latency computing] * [CreditProposal Credit system proposal] * [OrgGrid Organizational Grid Management] * [SchedMatch Scheduler job matchmaking] == Implementation notes == === Client === * [ClientFiles File structure] * [ClientFsm FSM structure] * [ClientData Data structures] * [ClientLogic Main loop logic] * [ClientSched Client scheduling policies] * [HostMeasurement Host measurements] * [HostId Host identification] * [ClientApp Core client/application interaction (basic)] * [AutoAttach Automatic attach] * [AutoUpdate Automatic update] * [MemoryManagement Memory management] * [ScreensaverLogic Screensaver logic] * [/sandbox.php Sandbox implementation] * [ManagerImpl BOINC Manager] * [ClientSetupLogicWin Windows installer (V5) ] * [UnixClientPackage Client package layout for Unix] === Server programs === * [DataBase The BOINC database] * [BackendState Backend state transitions] * [BackendLogic The logic of backend programs] * [ServerDebug Debugging server components] * [ServerSecurity Notes on BOINC server security] * [DbDump Export statistics for 3rd-party sites] * [SingleJobImpl Single-job submission] === Packaging === * [UnixClientPackage Unix client packaging] * [RpmSpec Spec info for RPMs] * [UnixProjectPackage Unix project packaging] === PHP code (web pages and RPCs) === * [PhpDb PHP database abstraction layer] * [StyleSheets Style Sheets] === Protocols === * [CommIntro Protocol overview] * [RpcProtocol The scheduling server protocol] * [RpcPolicy Scheduling server timing and retry policies] * [FileUpload Data server protocol] * [PersFileXfer Persistent file transfers ] === Simulation === * [ClientSim Client simulator] * [/sim_form.php Web interface to client simulator] === Miscellaneous === * [CrossProjectId Cross-project identification] * [/loc_sim/ Project simulator] {{{ #!comment Is this a duplicate of ClientSim above? }}} * [PrefsImpl Preferences] * [TrickleImpl Trickle messages] * [VersionDiff How to see what has changed between two versions of an executable] * [XmlFormat XML formats] * [DiagnosticsApi Diagnostics API] == Historical == Design docs for old versions, or for ideas that never happened. * [PythonFramework Python testing framework] * [/api_v4.php Version 4 runtime system] * [/mac_intel.php Mac/Intel plan] * [/mac_devgroup.php Old Mac project plan] * [/new_setup.php Design of version 5 setup] * [/menubar.php Mac Menubar] * [/sequence.php Work sequences] * [/suggestions.php Usability discussion] * [/disk_management.php Disk management]