|
| 1 | +--- |
| 2 | +title: Abstract Document |
| 3 | +category: Structural |
| 4 | +language: ur |
| 5 | +tag: |
| 6 | + - Extensibility |
| 7 | +--- |
| 8 | + |
| 9 | +## ارادہ |
| 10 | + |
| 11 | +متحرک خصوصیات کا استعمال کریں اور ٹائپ سیفٹی کو برقرار رکھتے ہوئے غیر ٹائپ شدہ زبانوں کی لچک حاصل کریں۔ |
| 12 | + |
| 13 | +## وضاحت |
| 14 | + |
| 15 | +خلاصہ دستاویز کا پیٹرن اضافی، غیر جامد خصوصیات کو سنبھالنے کے قابل بناتا ہے۔ یہ پیٹرن قسم کی حفاظت اور مختلف کلاسوں کی الگ الگ خصوصیات کو انٹرفیس کے سیٹ میں فعال کرنے کے لیے خصلتوں کے تصور کا استعمال کرتا ہے۔ |
| 16 | + |
| 17 | +حقیقی مثال |
| 18 | + |
| 19 | +> ایک ایسی کار پر غور کریں جو متعدد حصوں پر مشتمل ہو۔ تاہم ہم نہیں جانتے کہ آیا مخصوص کار میں واقعی تمام پرزے ہیں یا ان میں سے کچھ ۔ ہماری کاریں متحرک اور انتہائی لچکدار ہیں۔ |
| 20 | +
|
| 21 | +صاف لفظوں میں |
| 22 | + |
| 23 | +> خلاصہ دستاویز کا پیٹرن اشیاء کے بارے میں جانے بغیر خصوصیات کو منسلک کرنے کی اجازت دیتا ہے۔ |
| 24 | +
|
| 25 | +ویکیپیڈیا کہتا ہے۔ |
| 26 | + |
| 27 | +> ڈھیلے ٹائپ شدہ کلیدی قدر والے اسٹورز میں اشیاء کو منظم کرنے اور ٹائپ شدہ نظاروں کا استعمال کرتے ہوئے ڈیٹا کو ظاہر کرنے کے لیے آبجیکٹ پر مبنی ساختی ڈیزائن کا نمونہ۔ پیٹرن کا مقصد اجزاء کے درمیان اعلی درجے کی لچک حاصل کرنا ہے۔ |
| 28 | +سختی سے ٹائپ کی گئی زبان میں جہاں قسم کی حفاظت کی حمایت کو کھونے کے بغیر، فلائی پر آبجیکٹ ٹری میں نئی خصوصیات شامل کی جا سکتی ہیں۔پیٹرن کلاس کی مختلف خصوصیات کو مختلف انٹرفیس میں الگ کرنے کے لیے خصلتوں کا استعمال کرتا ہے۔ |
| 29 | + |
| 30 | +**پروگرامی مثال** |
| 31 | + |
| 32 | +آئیے پہلے بیس کلاسز `Document` اور `AbstractDocument` کی وضاحت کرتے ہیں۔ |
| 33 | +وہ بنیادی طور پر آبجیکٹ کو پراپرٹی کا نقشہ اور کسی بھی مقدار میں چائلڈ آبجیکٹ رکھتے ہیں۔ |
| 34 | + |
| 35 | +```java |
| 36 | +public interface Document { |
| 37 | + |
| 38 | + Void put(String key, Object value); |
| 39 | + |
| 40 | + Object get(String key); |
| 41 | + |
| 42 | + <T> Stream<T> children(String key, Function<Map<String, Object>, T> constructor); |
| 43 | +} |
| 44 | + |
| 45 | +public abstract class AbstractDocument implements Document { |
| 46 | + |
| 47 | + private final Map<String, Object> properties; |
| 48 | + |
| 49 | + protected AbstractDocument(Map<String, Object> properties) { |
| 50 | + Objects.requireNonNull(properties, "properties map is required"); |
| 51 | + this.properties = properties; |
| 52 | + } |
| 53 | + |
| 54 | + @Override |
| 55 | + public Void put(String key, Object value) { |
| 56 | + properties.put(key, value); |
| 57 | + return null; |
| 58 | + } |
| 59 | + |
| 60 | + @Override |
| 61 | + public Object get(String key) { |
| 62 | + return properties.get(key); |
| 63 | + } |
| 64 | + |
| 65 | + @Override |
| 66 | + public <T> Stream<T> children(String key, Function<Map<String, Object>, T> constructor) { |
| 67 | + return Stream.ofNullable(get(key)) |
| 68 | + .filter(Objects::nonNull) |
| 69 | + .map(el -> (List<Map<String, Object>>) el) |
| 70 | + .findAny() |
| 71 | + .stream() |
| 72 | + .flatMap(Collection::stream) |
| 73 | + .map(constructor); |
| 74 | + } |
| 75 | + ... |
| 76 | +} |
| 77 | +``` |
| 78 | +اس کے بعد ہم ایک enum `Property` اور type, price, model اور parts کے لئے انٹرفیس کا ایک سیٹ بیان کرتے ہیں۔ یہ ہمیں تخلیق کرنے کی اجازت دیتا ہے۔ |
| 79 | +ہماری `Car` کلاس میں جامد نظر آنے والا انٹرفیس۔ |
| 80 | + |
| 81 | +```java |
| 82 | +public enum Property { |
| 83 | + |
| 84 | + PARTS, TYPE, PRICE, MODEL |
| 85 | +} |
| 86 | + |
| 87 | +public interface HasType extends Document { |
| 88 | + |
| 89 | + default Optional<String> getType() { |
| 90 | + return Optional.ofNullable((String) get(Property.TYPE.toString())); |
| 91 | + } |
| 92 | +} |
| 93 | + |
| 94 | +public interface HasPrice extends Document { |
| 95 | + |
| 96 | + default Optional<Number> getPrice() { |
| 97 | + return Optional.ofNullable((Number) get(Property.PRICE.toString())); |
| 98 | + } |
| 99 | +} |
| 100 | +public interface HasModel extends Document { |
| 101 | + |
| 102 | + default Optional<String> getModel() { |
| 103 | + return Optional.ofNullable((String) get(Property.MODEL.toString())); |
| 104 | + } |
| 105 | +} |
| 106 | + |
| 107 | +public interface HasParts extends Document { |
| 108 | + |
| 109 | + default Stream<Part> getParts() { |
| 110 | + return children(Property.PARTS.toString(), Part::new); |
| 111 | + } |
| 112 | +} |
| 113 | +``` |
| 114 | +اب ہم 'کار' متعارف کرانے کے لیے تیار ہیں۔ |
| 115 | + |
| 116 | +```java |
| 117 | +public class Car extends AbstractDocument implements HasModel, HasPrice, HasParts { |
| 118 | + |
| 119 | + public Car(Map<String, Object> properties) { |
| 120 | + super(properties); |
| 121 | + } |
| 122 | +} |
| 123 | +``` |
| 124 | + |
| 125 | +اور آخر کار یہ ہے کہ ہم ایک مکمل مثال میں 'کار' کو کیسے بناتے اور استعمال کرتے ہیں۔ |
| 126 | + |
| 127 | +```java |
| 128 | + LOGGER.info("Constructing parts and car"); |
| 129 | + |
| 130 | + var wheelProperties = Map.of( |
| 131 | + Property.TYPE.toString(), "wheel", |
| 132 | + Property.MODEL.toString(), "15C", |
| 133 | + Property.PRICE.toString(), 100L); |
| 134 | + |
| 135 | + var doorProperties = Map.of( |
| 136 | + Property.TYPE.toString(), "door", |
| 137 | + Property.MODEL.toString(), "Lambo", |
| 138 | + Property.PRICE.toString(), 300L); |
| 139 | + |
| 140 | + var carProperties = Map.of( |
| 141 | + Property.MODEL.toString(), "300SL", |
| 142 | + Property.PRICE.toString(), 10000L, |
| 143 | + Property.PARTS.toString(), List.of(wheelProperties, doorProperties)); |
| 144 | + |
| 145 | + var car = new Car(carProperties); |
| 146 | + |
| 147 | + LOGGER.info("Here is our car:"); |
| 148 | + LOGGER.info("-> model: {}", car.getModel().orElseThrow()); |
| 149 | + LOGGER.info("-> price: {}", car.getPrice().orElseThrow()); |
| 150 | + LOGGER.info("-> parts: "); |
| 151 | + car.getParts().forEach(p -> LOGGER.info("\t{}/{}/{}", |
| 152 | + p.getType().orElse(null), |
| 153 | + p.getModel().orElse(null), |
| 154 | + p.getPrice().orElse(null)) |
| 155 | + ); |
| 156 | + |
| 157 | + |
| 158 | +``` |
| 159 | + |
| 160 | +## کلاس ڈایاگرام |
| 161 | + |
| 162 | + |
| 163 | + |
| 164 | +## استعمال |
| 165 | + |
| 166 | +خلاصہ دستاویز کا پیٹرن استعمال کریں جب - |
| 167 | + |
| 168 | +* نئ پراپرٹیز آن دی فلائی شامل کرنے کی ضرورت ہے۔ |
| 169 | +* آپ ڈھانچے جیسے درخت میں ڈومین کو منظم کرنے کا ایک لچکدار طریقہ چاہتے ہیں۔ |
| 170 | +* آپ کو زیادہ ڈھیلا ڈھالا نظام چاہتے ہیں۔ |
| 171 | + |
| 172 | +## کریڈٹ |
| 173 | + |
| 174 | +* [Wikipedia: Abstract Document Pattern](https://en.wikipedia.org/wiki/Abstract_Document_Pattern) |
| 175 | +* [Martin Fowler: Dealing with properties](http://martinfowler.com/apsupp/properties.pdf) |
| 176 | +* [Pattern-Oriented Software Architecture Volume 4: A Pattern Language for Distributed Computing (v. 4)](https://www.amazon.com/gp/product/0470059028/ref=as_li_qf_asin_il_tl?ie=UTF8&tag=javadesignpat-20&creative=9325&linkCode=as2&creativeASIN=0470059028&linkId=e3aacaea7017258acf184f9f3283b492) |
0 commit comments