This package provides implementation of basic PHP datatypes.
In order to bundle our efforts we would like to collect all issues regarding this package in the main project repository's issue tracker.
Please reference the originating repository as the first element of the issue title e.g.:
[appserver-io/<ORIGINATING_REPO>] A issue I am having
This package provides classes representing an object oriented implementation for some basic datatypes.
As there has been (and still are) many discussions about PHP and type safety i decided to implement a small, really basic library that will offer the most basic datatype needed in nearly every project. To be honest, I really like almost all of those nice possibilities languages like Java provides, but as PHP is not Java, you always have to find a neat way to implement similar things in a way that makes sense in a PHP environment.
The intention for implementing those classes was the possibility to make your critical functions and methods Type-Safe, by using them for type hinting on one hand and the possibility to have a quick and easy to use kind of data validation mechanism on the other hand.
As you may know, using type hints will probably slow down your code a bit, so take care when you use them and always have an eye on possible performance impacts by running performance tests regularly.
The data type implementations this library will provide, are
- Objct
- Boolean
- Integer
- Flt
- Strng
The following examples wil give you a short introduction about the functionality each class will provide and how you can use it in your code. Please be aware, that the examples are not intended to make any sense, they should only give you an idea what is possible.
The abstract class Objct
implements a low level presentation of a class. All other classes of this library use it
as superclass.
Using a Boolean
instance to compare against another one or try to instantiate it with a not boolean value.
// initialize a new Integer instance
$bool = new Boolean(true);
$bool->equals(new Boolean(false)); // false
// throws a ClassCastException
$invalid = new Boolean('aValue');
Here are some examples how you can use the Integer
class
// initialize a new Integer instance
$int = new Integer(17);
// get the float value of the Integer
echo $int->floatValue() . PHP_EOL; // 17.0
echo $int->stringValue() . PHP_EOL; // '17'
// check that the two Integer instances are equal
$int->equals(Integer::valueOf(new String('17'))); // true
The example for using a Flt
shows you how to add to instances
and print the float value
// initialize a new Float instance
$float = new Flt(10.005);
$float->add(new Flt(10.105));
// check the value
echo $float->floatValue() . PHP_EOL; // 20.11
To show you how you can use the Strng
class we'll simple concatenate
to instances
// initialize a new String instance
$string = new Strng('value to');
// check that String was successfully concatenated
echo $string->concat(new Strng(' search')) . PHP_EOL; // 'value to search'
Yeah, this are really simple examples, and as i told you before in most cases i'll use that classes for simple things like type hints and so on.
If you like to use that stuff also, feel free to implement your own types and send me a pull request :)
- Documentation at appserver.io