appserver-io / lang
Lang package implementation providing basic PHP datatypes.
Installs: 14 077
Dependents: 10
Suggesters: 0
Security: 0
Stars: 14
Watchers: 4
Forks: 14
Open Issues: 1
Requires
- php: >=5.4.0
- herrera-io/annotations: 1.0.*
Requires (Dev)
- appserver-io/build: ~2.0
README
Introduction
This package provides implementation of basic PHP datatypes.
Issues
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
Usage
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.
Objct (Object before version 5.0)
The abstract class Objct
implements a low level presentation of a class. All other classes of this library use it
as superclass.
Boolean
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');
Integer
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
Flt (Float before version 3.0)
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
Strng (String before version 3.0)
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 :)
External Links
- Documentation at appserver.io