Skip to content

Commit

Permalink
Updated Base to 4.0-2235
Browse files Browse the repository at this point in the history
  • Loading branch information
RisingFog committed Jul 22, 2014
1 parent 16cb3dc commit 693ecea
Show file tree
Hide file tree
Showing 380 changed files with 3,827 additions and 26,075 deletions.
12 changes: 4 additions & 8 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -197,6 +197,8 @@ if(NOT MSVC)
check_and_add_flag(LOGICAL_OP -Wlogical-op)
check_and_add_flag(SHADOW -Wshadow)
check_and_add_flag(INIT_SELF -Winit-self)
check_and_add_flag(MISSING_DECLARATIONS -Wmissing-declarations)
check_and_add_flag(MISSING_VARIABLE_DECLARATIONS -Wmissing-variable-declarations)
endif(NOT MSVC)

# gcc uses some optimizations which might break stuff without this flag
Expand Down Expand Up @@ -267,10 +269,6 @@ if(APPLE)
# page on x86_64 is 4GB in size.
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,-pagezero_size,0x1000")

if(NOT DISABLE_WX)
add_definitions(-DUSE_WX -DHAVE_WX)
set(USE_WX TRUE)
endif()
find_library(APPKIT_LIBRARY AppKit)
find_library(APPSERV_LIBRARY ApplicationServices)
find_library(ATB_LIBRARY AudioToolbox)
Expand Down Expand Up @@ -683,10 +681,8 @@ if(NOT DISABLE_WX AND NOT ANDROID)
ERROR_QUIET
)
message("Found wxWidgets version ${wxWidgets_VERSION}")
if(UNIX AND NOT APPLE)
set(wxMIN_VERSION "2.9.3")
else()
set(wxMIN_VERSION "2.9.4")
if(UNIX)
set(wxMIN_VERSION "3.0.0")
endif()
if(${wxWidgets_VERSION} VERSION_LESS ${wxMIN_VERSION})
message("At least ${wxMIN_VERSION} is required; ignoring found version")
Expand Down
10 changes: 5 additions & 5 deletions CMakeTests/CheckLib.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -55,17 +55,17 @@ endmacro()

macro(check_libav)
if(PKG_CONFIG_FOUND)
pkg_check_modules(LIBAV libavcodec>=53.35.0 libavformat>=53.21.0
libswscale>=2.1.0 libavutil>=51.22.1)
pkg_check_modules(LIBAV libavcodec>=54.35.0 libavformat>=54.20.4
libswscale>=2.1.1 libavutil>=52.3.0)
else()
message("pkg-config is required to check for libav")
message("pkg-config is required to check for libav/ffmpeg")
endif()
if(LIBAV_FOUND)
message("libav found, enabling AVI frame dumps")
message("libav/ffmpeg found, enabling AVI frame dumps")
add_definitions(-DHAVE_LIBAV)
include_directories(${LIBAV_INCLUDE_DIRS})
else()
message("libav not found, disabling AVI frame dumps")
message("libav/ffmpeg not found, disabling AVI frame dumps")
endif()
endmacro()

221 changes: 221 additions & 0 deletions Contributing.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,221 @@
# Dolphin Code Styling

## Table of Contents
---

- [Introduction] (#introduction)
- [Styling and formatting] (#styling-and-formatting)
- [General] (#general)
- [Naming] (#naming)
- [Conditionals] (#conditionals)
- [Classes and Structs] (#classes-and-structs)
- [Code specific] (#code-specific)
- [General] (#general-1)
- [Headers] (#headers)
- [Loops] (#loops)
- [Functions] (#functions)
- [Classes and Structs] (#classes-and-structs-1)


## Introduction
---

This guide is for developers who wish to contribute to the Dolphin codebase. It will detail how to properly style and format code to fit this project. This guide also offers suggestions on specific functions and other varia that may be used in code.

Following this guide and formatting your code as detailed will likely get your pull request merged much faster than if you don't (assuming the written code has no mistakes in itself).

## Styling and formatting
---

### General
- Try to limit lines of code to a maximum of 100 characters.
- Note that this does not mean you should try and use all 100 characters every time you have the chance. Typically with well formatted code, you normally shouldn't hit a line count of anything over 80 or 90 characters.
- The indentation style we use is tabs for initial indentation and then, if vertical alignment is needed, spaces are to be used.
- The opening brace for namespaces, classes, functions, enums, structs, unions, conditionals, and loops go on the next line.
- With array initializer lists and lambda expressions it is OK to keep the brace on the same line.
- References and pointers have the ampersand or asterisk against the type name, not the variable name. Example: `int* var`, not `int *var`.
- Don't collapse single line conditional or loop bodies onto the same line as its header. Put it on the next line.
- Yes:

```c++
if (condition)
return 0;

while (var != 0)
var--;
```
- No:

```c++
if (condition) return 0;

while (var != 0) var--;
```

### Naming
- All class, enum, function, and struct names should be in upper CamelCase. If the name contains an abbreviation uppercase it.
- `class SomeClassName`
- `enum IPCCommandType`
- All compile time constants should be fully uppercased. With constants that have more than one word in them, use an underscore to separate them.
- `const int PI = 3.14159;`
- `const int MAX_PATH = 260;`
- All variables should be lowercase with underscores separating the individual words in the name.
- `int this_variable_name;`
- Please do not use [Hungarian notation](http://en.wikipedia.org/wiki/Hungarian_notation) prefixes with variables. The only exceptions to this are the variable prefixes below.
- Global variables – `g_`
- Class variables – `m_`
- Static variables – `s_`

### Conditionals
- Do not leave `else` or `else if` conditions dangling unless the `if` condition lacks braces.
- Yes:

```c++
if (condition)
{
// code
}
else
{
// code
}
```
- Acceptable:

```c++
if (condition)
// code line
else
// code line
```
- No:

```c++
if (condition)
{
// code
}
else
// code line
```


### Classes and Structs
- If making a [POD](http://en.wikipedia.org/wiki/Plain_Old_Data_Structures) type, use a `struct` for this. Use a `class` otherwise.
- Class layout should be in the order, `public`, `protected`, and then `private`.
- If one or more of these sections are not needed, then simply don't include them.
- For each of the above specified access levels, the contents of each should follow this given order: constructor, destructor, operator overloads, functions, then variables.
- When defining the variables, define `static` variables before the non-static ones.

```c++
class ExampleClass : public SomeParent
{
public:
ExampleClass(int x, int y);

int GetX() const;
int GetY() const;

protected:
virtual void SomeProtectedFunction() = 0;
static float s_some_variable;

private:
int m_x;
int m_y;
};
```

## Code Specific
---

### General
- Using C++11 features is OK and recommended.
- Use the [nullptr](http://en.cppreference.com/w/cpp/language/nullptr) type over the macro `NULL`.
- If a [range-based for loop](http://en.cppreference.com/w/cpp/language/range-for) can be used instead of container iterators, use it.
- Obviously, try not to use `goto` unless you have a *really* good reason for it.
- If a compiler warning is found, please try and fix it.
- Try to avoid using raw pointers (pointers allocated with `new`) as much as possible. There are cases where using a raw pointer is unavoidable, and in these situations it is OK to use them. An example of this is functions from a C library that require them. In cases where it is avoidable, the STL usually has a means to solve this (`vector`, `unique_ptr`, etc).
- Do not use the `auto` keyword everywhere. While it's nice that the type can be determined by the compiler, it cannot be resolved at 'readtime' by the developer as easily. Use auto only in cases where it is obvious what the type being assigned is (note: 'obvious' means not having to open other files or reading the header file). Some situations where it is appropriate to use `auto` is when iterating over a `std::map` container in a foreach loop, or to shorten the length of container iterator variable declarations.
- Do not use `using namespace [x];` in headers. Try not to use it at all if you can.
- The preferred form of the increment and decrement operator is prefix (e.g. `++var`).

### Headers
- If a header is not necessary in a certain source file, remove them.
- If you find duplicate includes of a certain header, remove it.
- When declaring includes in a source file, make sure they follow the given pattern:
- Standard library headers
- System-specific headers (these should also likely be in an `#ifdef` block unless the source file itself is system-specific).
- Dolphin source file headers
- Each of the above header sections should also be in alphabetical order
- Project source file headers should be included in a way that is relative to the `[Dolphin Root]/Source/Core` directory.
- This project uses `#pragma once` as header guards.

### Loops
- If an infinite loop is required, do not use `for (;;)`, use `while (true)`.
- Empty-bodied loops should use braces after their header, not a semicolon.
- Yes: `while (condition) {}`
- No: `while (condition);`

### Functions
- If a function parameter is a pointer or reference and its value or data isn't intended to be changed, please mark that parameter as `const`.
- Functions that specifically modify their parameters should have the respective parameter(s) marked as a pointer so that the variables being modified are syntaxically obvious.
- What not to do:

```c++
template<class T>
inline void Clamp(T& val, const T& min, const T& max)
{
if (val < min)
val = min;
else if (val > max)
val = max;
}
```

Example call: `Clamp(var, 1000, 5000);`

- What to do:

```c++
template<class T>
inline void Clamp(T* val, const T& min, const T& max)
{
if (*val < min)
*val = min;
else if (*val > max)
*val = max;
}
```

Example call: `Clamp(&var, 1000, 5000);`

- Class member functions that you do not want to be overridden in inheriting classes should be marked with the `final` specifier.

```c++
class ClassName : ParentClass
{
public:
void Update() final;
};
```
- Overridden member functions that can also be inherited should be marked with the `override` specifier to make it easier to see which functions belong to the parent class.
```c++
class ClassName : ParentClass
{
public:
void Update() override;
};
```

### Classes and Structs
- Classes and structs that are not intended to be extended through inheritance should be marked with the `final` specifier.

```c++
class ClassName final : ParentClass
{
// Class definitions
};
```
4 changes: 3 additions & 1 deletion Data/Sys/GameSettings/NAKP01.ini
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,6 @@ EmulationIssues = Controlls won't work in-game
[ActionReplay]
# Add action replay cheats here.
[Video_Hacks]
EFBToTextureEnable = False
EFBCopyEnable = True
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/16bit.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/32bit.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/FXAA.glsl
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@

// 0. You just DO WHAT THE FUCK YOU WANT TO.

uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
4 changes: 2 additions & 2 deletions Data/Sys/Shaders/README.txt
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
//dummy shader:
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand All @@ -15,4 +15,4 @@ For best results, turn Wordwrap formatting on...
The shaders shown in the dropdown box in the video plugin configuration window are kept in the directory named User/Data/Shaders. They are linked in to the dolphin source from the repository at <http://dolphin-shaders-database.googlecode.com/svn/trunk/>. See <http://code.google.com/p/dolphin-shaders-database/wiki/Documentation> for more details on the way shaders work.

This file will hopefully hold more content in future...
*/
*/
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/acidmetal.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/acidtrip.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/acidtrip2.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
4 changes: 2 additions & 2 deletions Data/Sys/Shaders/asciiart.glsl
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
// textures
uniform sampler2D samp8;
uniform sampler2D samp9;
SAMPLER_BINDING(8) uniform sampler2D samp8;
SAMPLER_BINDING(9) uniform sampler2D samp9;

const int char_width = 8;
const int char_height = 13;
Expand Down
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/auto_toon.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/auto_toon2.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/bad_bloom.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/brighten.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/chrismas.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/cool1.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/darkerbrighter.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
2 changes: 1 addition & 1 deletion Data/Sys/Shaders/emboss.glsl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
uniform sampler2D samp9;
SAMPLER_BINDING(9) uniform sampler2D samp9;

out vec4 ocol0;
in vec2 uv0;
Expand Down
Loading

0 comments on commit 693ecea

Please sign in to comment.