Niezalogowany [ logowanie ]
Subskrybuj kanał ATOM Kanał ATOM

Autor wpisu: JoShiMa, dodany: 31.12.2017 21:26, tagi: framework

Zanim się nauczę tej sekwencji na pamięć potrzebuję ściągi. Jak wiadomo najlepsza jest ściąga, którą się tworzy samemu więc postanowiłam sobie taką zapisać i mieć pod ręką. Zatem za chwilę krok po kroku tworzenia aplikacji Django pod Linuksem z wykorzystaniem środowiska wirtualnego. W swoim katalogu z projektami tworzonymi w Pythonie mam osobne katalogi dla wirtualnych […]

Autor wpisu: JoShiMa, dodany: 30.12.2017 02:01, tagi: framework, php

Tak. Zaczęłam miesiąc temu swoją przygodę z Symfony. Długo trzymałam się z daleka od tego frameworka. Dziś właściwie nie wiem z jakie były powody mojego postępowania. Życie mnie przymusiło, żeby się jednak z nim zapoznać i prawdę mówiąc, nie żałuję. Oczywiście nie ma dnia, żebym nie zmagała się z zupełnie nowymi dla mnie zagadnieniami. Ot […]

Autor wpisu: Piotr Pasich, dodany: 20.11.2017 08:00, tagi: php

Screen-Shot-2017-10-23-at-5.59.30-PM-e1508796050361Paying for goods with Bitcoin is becoming more and more popular. If you run, maintain or develop an e-commerce website, ICO project, exchange, or trading system, you may be interested in a quick way of integrating with the Bitcoin blockchain. This article will show one of many ways of installing a Bitcoin mining software and […]

Autor wpisu: JoShiMa, dodany: 16.11.2017 01:30, tagi: framework

Miałam zamiar napisać sobie notatkę z instrukcją tworzenia projektu w Django. Doszłam jednak do wniosku, że takie instrukcje łatwo można znaleźć w sieci, nawet po polsku. Zamiast tego napisałam instrukcję instalowania projektu Django na hostingu wykupionym w MyDevil. Oczywiście wszystkie (albo prawie wszystkie) informacje znajdują się w dokumentacji udostępnionej przez MyDevil. Jednak dla mnie, kompletnie […]

Autor wpisu: Piotr Pasich, dodany: 19.10.2017 21:04, tagi: php

cryptoJust a couple months ago, I was asked to participate in a project that operates with the cryptocurrency networks. And I had a pretty basic knowledge about a blockchain that time, which was not enough. During the development we realized this is a common problem and finding a highly qualified programmer who used to work […]

Autor wpisu: Michał Janicki, dodany: 01.10.2017 12:51, tagi: php

W tym poście opiszę w jaki sposób można tworzyć własne reguły i zestawy reguł dla PHPMD. Jeśli chciałbyś się dowiedzieć czym jest PHPMD lub uzupełnić wiedzę na ten temat to zapraszam do lektury poprzedniego postu opisującego od podstaw PHPMD. Zachęcam także do zapoznania się z tym i z tym postem – oba poświęcone są narzędziom do statycznej analizy kodu.

I jeszcze jedna uwaga – przykłady znajdujących się w tym poście jest zaczerpniętych bezpośrednio z dokumentacji PHPMD.

A teraz o tworzeniu własnych reguł

W pierwszej kolejności należy utworzyć plik z klasą, która będzie implementować interface \PHPMD\Rule. Znacznie lepszym rozwiązaniem będzie jednak zamiast implementować ten interface rozszerzyć klasę \PHPMD\AbstractRule. Zawiera ona całą logikę niezbędną do utworzenia klasy z regułą.

Kolejnym krokiem będzie stworzenie wewnątrz klasy metody apply, która jako argument przyjmuje obiekt będący instancją \PHPMD\AbstractNode. Ten obiekt reprezentuje klasę, metodę, funkcję lub interface, który możemy poddać testom. Pytanie jednak skąd wiadomo, że ten obiekt zawiera klasę a nie np. metodę? Aby to określić należy implementować jeden z czterech specjalnych interfaceów (\PHPMD\Rule\ClassAware, \PHPMD\Rule\FunctionAware, \PHPMD\Rule\InterfaceAware, \PHPMD\Rule\MethodAware). Ich jedynym zadaniem jest oznaczenie jakiego typu element testowanego kodu (klasa, funkcja, metoda, interface) będzie przekazywany w parametrze do metody apply. Przykład klasy poniżej:

class Com_Example_Rule_NoFunctions extends \PHPMD\AbstractRule
  implements \PHPMD\Rule\FunctionAware
{
  public function apply(\PHPMD\AbstractNode $node)
  {
  }
}

Teraz pozostaje tylko wywołać metodę addViolation, która dodaje informacje o błędzie do raportu końcowego w odpowiednim miejscu.

A teraz o regułach bazujących na danych z PHP Depend

PHPMD może posłużyć także do analizy istniejących już danych zwróconych PHP Depend i na ich bazie określić czy z kodem jest coś nie tak. Zasada tworzenia takiej reguły jest bardzo podobna do tych analizujących kod.

Pierwsze z czym należy się zapoznać to z listą metryk jakie oferuje PHP_Depend. Znajdziemy tam tabelę, w której każdy wiersz opisuje jedną metrykę. Gdy wybierzemy już, która metryka nas najbardziej interesuje przechodzimy do metody apply w na parametrze $node wywołujemy metodę getMetric i jako parametr podajemy nazwę metryki PHP_Depend. Metoda getMetric zwróci nam wartość, którą następnie możemy poddać analizie w samej metodzie apply. Klasa analizująca metrykę powinna być podobna do klasy poniżej:

Czytaj dalej tutaj (rozwija treść wpisu)
Czytaj dalej na blogu autora...

Autor wpisu: Michał Janicki, dodany: 21.08.2017 21:24, tagi: php

PHP Mess Detector jest kolejnym narzędziem po PHP_CodeSniffer i kilku innych wcześniej opisanych w tym i w tym poście narzędzi służących do statycznej analizy kodu jakie opiszę. Jeśli z jakiegoś powodu nie przeczytałeś tych wpisów to bardzo zachęcam do zapoznania się z nimi.

A teraz ogólnie o PHPMD

PHPMD (bo tak w skrócie nazwa się to narzędzie) jest to „odprysk” powstały w wyniku tworzenia narzędzia zwanego PHPDepend. Podobnie jak PHP_CodeSniffer najlepiej sprawdza się gdy chcemy przekonać się które fragmenty naszego kodu potencjalnie mogą zawierać błędy, nieużywane parametry lub wskaże fragmenty, które są zbyt skomplikowane.

A teraz o instalacji PHPMD

Sposoby instalacji są raczej standardowe. Po pierwsze można pobrać plik phar za pomocą następującego polecenia:

$ wget -c http://static.phpmd.org/php/latest/phpmd.phar

lub dodać zależność do pliku composer.json:

{
    "require-dev": {
        "phpmd/phpmd" : "@stable"
        }
}

potem wpisujemy:

Czytaj dalej tutaj (rozwija treść wpisu)
Czytaj dalej na blogu autora...

Wszystkie wpisy należą do ich twórców. PHP.pl nie ponosi odpowiedzialności za treść wpisów.