2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# Contributing
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Citra is a brand new project, so we have a great opportunity to keep things clean and well organized early on. As such, coding style is very important when making commits. They aren't very strict rules since we want to be flexible and we understand that under certain circumstances some of them can be counterproductive. Just try to follow as many of them as possible:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### General Rules
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  A lot of code was taken from other projects (e.g. Dolphin, PPSSPP, Gekko, SkyEye). In general, when editing other people's code, follow the style of the module you're in (or better yet, fix the style if it drastically differs from our guide). 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Line width is typically 100 characters, but this isn't strictly enforced. Please do not use 80-characters. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Don't ever introduce new external dependencies into Core 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Don't use any platform specific code in Core 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Use namespaces often 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Naming Rules
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  Functions 
						 
					
						
							
								
									
										
										
										
											2014-06-01 15:31:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  CamelCase, "_" may also be used for clarity (e.g. ARM_InitCore)
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  Variables 
						 
					
						
							
								
									
										
										
										
											2014-06-01 15:31:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  lower_case_underscored
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 *  Prefix "g_" if global
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  Classes 
						 
					
						
							
								
									
										
										
										
											2014-06-01 15:31:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  CamelCase, "_" may also be used for clarity (e.g. OGL_VideoInterface)
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  Files/Folders 
						 
					
						
							
								
									
										
										
										
											2014-06-01 15:31:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  lower_case_underscored
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  Namespaces 
						 
					
						
							
								
									
										
										
										
											2014-06-01 15:31:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 *  CamelCase, "_" may also be used for clarity (e.g. ARM_InitCore)
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Indentation/Whitespace Style
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Follow the indentation/whitespace style shown below. Do not use tabs, use 4-spaces instead.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```cpp
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								namespace Example {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								// Namespace contents are not indented
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								// Declare globals at the top
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								int g_foo = 0;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								char* g_some_pointer; // Notice the position of the *
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								enum SomeEnum {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    COLOR_RED,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    COLOR_GREEN,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    COLOR_BLUE
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								struct Position {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    int x, y;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								};
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								// Use "typename" rather than "class" here, just to be consistent
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								template
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								void FooBar() {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    int some_array[] = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        5,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        25,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        7,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        42
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    };
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    if (note == the_space_after_the_if) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        CallAfunction();
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } else {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // Use a space after the // when commenting
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    // Comment directly above code when possible
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if (some_condition) single_statement();
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    // Place a single space after the for loop semicolons
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for (int i = 0; i != 25; ++i) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // This is how we write loops
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    DoStuff(this, function, call, takes, up, multiple,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            lines, like, this);
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    if (this || condition_takes_up_multiple & & 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        lines & &  like & &  this || everything ||
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        alright || then) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    switch (var) {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    // No indentation for case label
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case 1: {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        int case_var = var + 3;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        DoSomething(case_var);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    case 3:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        DoSomething(var);
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return;
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    default:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        // Yes, even break for the last case
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        break;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-06-01 15:31:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    std::vector
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        you_can_declare,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        a_few,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        variables,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        like_this;
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2014-11-19 08:49:13 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2014-05-20 14:52:02 -07:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```