Improved Euler Blogpost:
- Better links to problems - Show Abbreviated code message - Download link to github - More prominent download button
This commit is contained in:
parent
a83b746f9d
commit
8d84152726
@ -9,5 +9,4 @@ defined('YII_DEBUG') or define('YII_DEBUG',true);
|
||||
// dev or prod - merges settings with respective file
|
||||
defined('YII_CUSTOM_ENV') or define('YII_CUSTOM_ENV', 'dev');
|
||||
|
||||
require_once($yii);
|
||||
Yii::createWebApplication($config)->run();
|
||||
require_once($yii);
|
@ -100,6 +100,8 @@ return ArrayX::merge(
|
||||
'blog/<id>' => 'blogPost/view/id/<id>',
|
||||
'blog/<id>/<name>' => 'blogPost/view/id/<id>',
|
||||
|
||||
'blog/1/<name>/<problem>' => 'blogPost/view/id/1',
|
||||
|
||||
'eulerproblem/' => 'eulerproblem/index',
|
||||
|
||||
'Highscores/list.php' => 'Highscores/list', // Compatibility
|
||||
|
@ -244,8 +244,9 @@ class BlogPostController extends MSController
|
||||
$problems = EulerProblem::model()->findAll(['order'=>'Problemnumber']);
|
||||
|
||||
$problemnumber = 0;
|
||||
if (isset($_GET['problem']) AND is_numeric($_GET['problem']))
|
||||
$problemnumber = $_GET['problem'];
|
||||
|
||||
if (isset($_GET['problem']) AND is_numeric(preg_replace('/^[Pp]roblem-/', '', $_GET['problem'])))
|
||||
$problemnumber = preg_replace('/^[Pp]roblem-/', '', $_GET['problem']);
|
||||
|
||||
$criteria=new CDbCriteria;
|
||||
$criteria->condition='Problemnumber = ' . $problemnumber;
|
||||
|
@ -124,6 +124,11 @@ class EulerProblem extends CActiveRecord
|
||||
return parent::model($className);
|
||||
}
|
||||
|
||||
public function getBlogLink()
|
||||
{
|
||||
return '/blog/1/Project_Euler_with_Befunge/problem-' . str_pad($this->Problemnumber, 3, '0', STR_PAD_LEFT);
|
||||
}
|
||||
|
||||
public function getSourcecodefile($absolute = true)
|
||||
{
|
||||
return ($absolute ? '/' : '') . 'data/blog/Befunge/Euler_Problem-' . str_pad($this->Problemnumber, 3, '0', STR_PAD_LEFT) . '.b93';
|
||||
@ -152,6 +157,11 @@ class EulerProblem extends CActiveRecord
|
||||
return $this->SolutionWidth <= 80 AND $this->SolutionHeight <= 25;
|
||||
}
|
||||
|
||||
public function getRawGithubLink()
|
||||
{
|
||||
return 'https://raw.githubusercontent.com/Mikescher/Project-Euler_Befunge/master/processed/Euler_Problem-' . str_pad($this->Problemnumber, 3, '0', STR_PAD_LEFT) . '.b93';
|
||||
}
|
||||
|
||||
public function generateMarkdown()
|
||||
{
|
||||
$num_padded = str_pad($this->Problemnumber, 3, '0', STR_PAD_LEFT);
|
||||
@ -165,13 +175,20 @@ class EulerProblem extends CActiveRecord
|
||||
'```befunge' . PHP_EOL .
|
||||
$this->Code . PHP_EOL .
|
||||
'```' . PHP_EOL .
|
||||
'[Download](/data/blog/Befunge/Euler_Problem-' . $num_padded . '.b93)' . PHP_EOL .
|
||||
|
||||
($this->AbbreviatedCode ?
|
||||
(
|
||||
'> **NOTE** ' . PHP_EOL .
|
||||
'> This program is too big to display here, click **[download]** to see the full program. ' . PHP_EOL . PHP_EOL
|
||||
) : '').
|
||||
|
||||
'<a class="btn btn-primary" href="' . $this->getRawGithubLink() . '">Download</a>' . PHP_EOL .
|
||||
'' . PHP_EOL .
|
||||
$this->Explanation . PHP_EOL .
|
||||
'' . PHP_EOL .
|
||||
'**Interpreter steps:** `' . number_format($this->SolutionSteps, 0, null, ',') . '` ' . PHP_EOL .
|
||||
'**Execution time** ([BefunExec](/programs/view/BefunGen)): `' . number_format($this->SolutionTime, 0, null, ',') . '` ms' . (($this->SolutionTime < 1000) ? (' ') : (' *(= ' . MsHelper::formatMilliseconds($this->SolutionTime) . ')* ')) . PHP_EOL .
|
||||
'**Program size:** `' . $this->SolutionWidth . 'x' . $this->SolutionHeight . '` ' . PHP_EOL .
|
||||
'**Program size:** `' . $this->SolutionWidth . 'x' . $this->SolutionHeight . '` ' . ($this->isBefunge93() ? '*(fully valid Befunge-93)*' : '') . ' ' . PHP_EOL .
|
||||
'**Solution:** `' . number_format($this->SolutionValue, 0, null, ',') . '` ';
|
||||
}
|
||||
}
|
||||
|
@ -75,7 +75,7 @@ array_push($this->css_files, "/css/blogpost_ProjectEulerBefunge_style.css");
|
||||
echo '<tr class="PEB_tablerowProblems">' . "\r\n";
|
||||
|
||||
echo '<td class="PEB_tablecellProblems PEB_TC_Number">' . $problem->Problemnumber . "</td>\r\n";
|
||||
echo '<td class="PEB_tablecellProblems PEB_TC_Title"><a href="?problem=' . $problems[$i]->Problemnumber . '">' . $problem->Problemtitle . "</a></td>\r\n";
|
||||
echo '<td class="PEB_tablecellProblems PEB_TC_Title"><a href="' . $problems[$i]->getBlogLink() . '">' . $problem->Problemtitle . "</a></td>\r\n";
|
||||
echo '<td class="PEB_tablecellProblems"><div class="PEB_TC_Time PEB_TC_Timelevel_' . $problem->getTimeScore() . '">' . MsHelper::formatMilliseconds($problem->SolutionTime) . "</div></td>\r\n";
|
||||
|
||||
if ($problem->isBefunge93())
|
||||
@ -118,7 +118,7 @@ array_push($this->css_files, "/css/blogpost_ProjectEulerBefunge_style.css");
|
||||
array_push($pagination,
|
||||
[
|
||||
'label' => str_pad($problems[$i]->Problemnumber, 3, '0', STR_PAD_LEFT),
|
||||
'url' => '?problem=' . $problems[$i]->Problemnumber,
|
||||
'url' => $problems[$i]->getBlogLink(),
|
||||
'disabled' => false,
|
||||
'active' => $currproblemID == $i,
|
||||
]);
|
||||
|
Loading…
Reference in New Issue
Block a user